牛客练习赛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 推荐阅读 漫威反派实力排名官方 漫威五大神明实力排名 关于社会劳动的名言 今日公测最新手游济南公交,济南公交线路查询 快速排序算法优点缺点分析,算法设计与分析快速排序实验报告 申请生育津贴的流程怎样的?生育津贴怎么查? 华为p30有广角功能吗 摩托车不易启动的原因 摩托车天冷打不着火是什么原因 梦见爸妈跟人打架了 梦见爸妈跟人打架 爱普生打印机废墨更换教程 淘宝外链是什么 淘宝如何外链相册 唐诗宋词之最都有哪些? 唐宋诗词之最? 电脑版相机 电脑拍照软件哪个好 2023年邯郸星际酒店春节特惠活动一览 耳朵看相:耳垂厚的人性格及运势 简单的痘印祛除小窍门 怎么祛痘印 梦见牛羊什么意思 蛋包饭为什么那么火 如何自制蛋包饭 法院对故意杀人犯罪的刑事刑罚内容是什么样的 前列腺|21岁大学生深陷“669”,患前列腺炎,医生:女朋友再漂亮,也要控制 匝道是什么意思 什么是匝道 算法刷题笔记|牛客网 NC20859 兔子的名字 算法刷题笔记|牛客网 字节跳动2019真题 聪明的编辑 正则表达式 牛客网|牛客练习赛25 背包|长方体的摆放