牛客练习赛34 ABCD题解 2022-01-06 牛客网 传送门 A #include #include #include #include #include #include #include #define ll long long #define N 0x3f3f3f3f using namespace std; int b[100010]; int main() { int t; cin>>t; ; while(t--) { string s; cin>>s; int m=s[s.size()-1]-'0'; if(m%2!=0) { s[s.size()-1]=s[s.size()-1]-1; } cout< B #include #include #include #include #include #include #include #define ll long long #define N 0x3f3f3f3f using namespace std; int b[100010]; int main() { int n; cin>>n; ll h=0; for(int i=0; i>b[i]; h+=b[i]; } if(h%2==0) { int ans=0; for(int i=0; i C #include #include #include #include #include #include #define ll long long #define N 0x3f3f3f3f using namespace std; int l[100010]; int r[100010]; int len[100010]; int s[100010]; int main() { int n,m; cin>>n>>m; int ans=0; memset(len,0,sizeof(len)); memset(s,0,sizeof(s)); for(int i=1; i<=m; i++) { cin>>l[i]>>r[i]; len[l[i]]++,len[r[i]+1]--; } for(int i=1; i<=n; i++) { len[i]+=len[i-1]; if(len[i]==0) { ans++; } } for(int i=1; i<=n; i++) { if(len[i]>1) { len[i]=0; } len[i]+=len[i-1]; } int pos=1; for(int i=1; i<=m; i++) { if(len[r[i]]-len[l[i]-1]<=len[r[pos]]-len[l[pos]-1]) pos=i; } cout<【牛客练习赛34 ABCD题解】 树状数组 #include #include #include #include #include #include #define ll long long #define N 0x3f3f3f3f using namespace std; int n,m; struct ac { int l,r; }a[101000]; int c[101000]; int num[101000]; int lowbit(int w) { return w&(-w); } void updata(int x) { while(x<=n) { c[x]+=1; x+=lowbit(x); } } int getsum(int x) { int sum=0; while(x>0) { sum+=c[x]; x-=lowbit(x); } return sum; } int main() { cin>>n>>m; memset(num,0,sizeof(num)); memset(c,0,sizeof(c)); for(int i=1; i<=m; i++) { cin>>a[i].l>>a[i].r; num[a[i].l]++,num[a[i].r+1]--; } int ans=0; for(int i=1; i<=n; i++) { num[i]+=num[i-1]; if(num[i]==0) ans++; if(num[i]==1) updata(i); } int sum=1e9; int pos; for(int i=1; i<=m; i++) { if(getsum(a[i].r)-getsum(a[i].l-1)<=sum) { pos=i; sum=getsum(a[i].r)-getsum(a[i].l-1); } } sum+=ans; cout< D #include #include #include #include #include #include #define ll long long #define N 0x3f3f3f3f using namespace std; int a[1010]; int main() { int n,m; cin>>n>>m; for(int i=0; i>a[i]; } sort(a,a+n); int ans=0; for(int i=0; i 推荐阅读 模拟信号是什么 水鸭煲汤怎么做好吃 分享这三点内容 遐怎么读组词 遐组词介绍 宸枫名字的寓意 刘涛演的电视剧有哪些 人生何处不相逢的全诗 人生何处不相逢下一句相逢何必曾相识 如何用圆方做橱柜设计视频 如何用圆方做橱柜设计,如何用圆方做橱柜设计图 网红辛巴又发出惊人言论,死后财产全部“裸捐”,这次所为何事? 海口到重庆机票 长沙到海口低价飞机票价格 日本相当于中国哪个省 韩国多少人 老年人首选 摩腹养生法 孩子认为啥都是自己的咋办? iphone自带的编曲软件,iphone上有编辑音乐的软件吗 世界湿地日是每年的什么时候,近十年湿地主题 Java毕业设计项目实战篇|Java项目:在线嘿嘿网盘系统设计和实现(java+Springboot+ssm+mysql+maven) js获取string类型的数组元素,js 获取string长度 热血江湖手游,巨灵攻城活动,怎么上排名? 汗腺|为啥总说“臭男人”,有被男人臭到的姐妹请举手! 谁能告诉我卷腹的正确做法?是不是跟仰卧起坐一样啊? 网上视频为什么不能播放,为什么网上有些视频不能播放 算法刷题笔记|牛客网 NC20859 兔子的名字 算法刷题笔记|牛客网 字节跳动2019真题 聪明的编辑 正则表达式 牛客网|牛客练习赛25 背包|长方体的摆放