牛客练习赛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 推荐阅读 降价|双11降价哪家强?iqoo:降900,三星:我降1300,荣耀:未知? 下厨房app菜单收藏方法 爱书签的孩子会有额外奖赏 金华个人所得税专项附加扣除指的是什么? 英语句法分析树 有哪些卖茶叶的天猫旗舰店值得推荐? 高仿尼康相机推荐 高仿尼康相机 蛤蜊的营养功效 射手座女生喜欢什么样的礼物 射手座女生漂亮吗 温州怎么查社保卡里有多少钱,怎么查社保余额 怎么用豆浆机打豆浆 怎么用豆浆机打豆浆好喝 ps怎么给图像加影子详细教程 阳台种什么植物 阳台种什么植物最旺风水 南极之恋是在南极拍的吗 vb.net设定为粗体 vb字体加粗代码后还原代码 快餐盒是什么材质的 孩子不阳光自信怎么办 榴莲,菠萝蜜,谁是你的最爱? 佳能35和50 佳能ef35与50 万答#13,MySQL自增键用完后,插入数据会发生什么情况 算法刷题笔记|牛客网 NC20859 兔子的名字 算法刷题笔记|牛客网 字节跳动2019真题 聪明的编辑 正则表达式 牛客网|牛客练习赛25 背包|长方体的摆放