17-09-10四校联考
T1:从高到低依次确定答案的每一位,如果每个区间的第i位都可以选1,那么全部选1,答案的这一位就是1。
如果该区间这一位能够选择0或1,那么将区间缩小为2i至ri。
如果不是所有区间都能选1,答案的这一位是0。
如果该区间这一位能够选择0或1,则该区间选0,并将所有比这一位低的位的值全部赋为1。时间复杂度O(n log 1018)。
Code:
1 #include<cstdio> 2 #include<cstring> 3 #include<algorithm> 4 #define ll long long 5 #define Lg 60 6 #define MN 100005 7 using namespace std; 8 inline ll in(){ 9 ll x=0;bool f=0; char c; 10 for (;(c=getchar())<'0'||c>'9';f=c=='-'); 11 for (x=c-'0';(c=getchar())>='0'&&c<='9';x=(x<<3)+(x<<1)+c-'0'); 12 return f?-x:x; 13 } 14 ll l[MN],r[MN],n,ans; 15 int main() 16 { 17 n=in();for (int i=1;i<=n;++i) l[i]=in(),r[i]=in(); 18 for (int i=Lg;i>=0;--i){ 19 bool f=0;for (int j=1;j<=n;++j) 20 if (!(r[j]&(1ll<<i))) {f=1;break;} 21 if (!f){ 22 ans+=(1ll<<i);for (int j=1;j<=n;++j) 23 if (!(l[j]&(1ll<<i))) l[j]=0; 24 }else for (int j=1;j<=n;++j) 25 if ((l[j]&(1ll<<i))!=(r[j]&(1ll<<i))) r[j]=(1ll<<Lg)-1; 26 }printf("%lld",ans);return 0; 27 }
【推荐】100%开源!大型工业跨平台软件C++源码提供,建模,组态!
【推荐】AI 的力量,开发者的翅膀:欢迎使用 AI 原生开发工具 TRAE
【推荐】2025 HarmonyOS 鸿蒙创新赛正式启动,百万大奖等你挑战
· 通过 Canvas 将后端发来的一帧帧图片渲染成“视频”的实现过程
· 当加密ID需要变成Guid:为什么我选择了AES-CBC而非GCM?
· 基于 epoll 的协程调度器——零基础深入浅出 C++20 协程
· 下划线字段在golang结构体中的应用
· SQL Server也能玩正则表达式?
· C#实现屏幕墙:同时监控多个电脑桌面(支持Windows、信创Linux、银河麒麟、统信UOS)
· 直击痛点的开源项目「GitHub 热点速览」
· C# 13 与 .NET 9 跨平台开发实战(第一章:开发环境搭建与.NET概述-上篇)
· 我的AI自学路线,可能对你有用
· 记一次 .NET 某自动化智能制造软件 卡死分析