Codeforces Round #715 (Div. 2) A题和B题
2021/4/17 10:30:20
本文主要是介绍Codeforces Round #715 (Div. 2) A题和B题,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
Codeforces Round #715 (Div. 2) A题和B题
传送门:A题
题目大意:N个整数代表身高,为了让数组中前后两个数的平均值都尽可能为整数,输出满足条件的数组。
思路分析:直接把数组中的奇数放在左边,偶数放在右边即可。
#include<iostream> #include<vector> using namespace std; typedef long long ll; int main() { int T; cin>>T; while(T--) { int n; cin>>n; int a[n]; for(int i=0;i<n;i++) cin>>a[i]; for(int i=0;i<n;i++) { if(a[i]%2!=0) cout<<a[i]<<' '; } for(int i=0;i<n;i++) { if(a[i]%2==0) cout<<a[i]<<' '; } cout<<endl; } }View Code
传送门:B题
题目大意:每一个给定长度的字符串按照某种方式分割以后,子串可以组装成多个“TMT”。(不能交换子串顺序)
思路分析:这题主要思想是贪心。那么怎么贪呢?字符个数为N,所以“M”字符的个数一定为N/3。从左往右每一个”M“都可以匹配到(它左边的,还没有被别人匹配的“T”)和(它右边的,还没有被别人匹配的“T”)。我们需要计算出数组任意位置前面“M”——cm和“T”的个数——ct。转换为数学语言就是每次更新cm和ct的时候都判断一下是否有cm>ct || ct-cm>n/3。除此之外还需要判断ct是否等于N/3。
#include<bits/stdc++.h> using namespace std; int main(){ int t,n; string s; cin>>t; while(t--){ cin>>n>>s; int ct=0, cm=0; bool ok=1; for(int i=0;i<n;i++){ if(s[i]=='T') ct++; if(s[i]=='M') cm++; if(cm>ct || ct-cm>n/3 ){ ok=0; break; } } if(ok && cm*2==ct) cout<<"YES"<<endl; else cout<<"NO"<<endl; } }View Code
这篇关于Codeforces Round #715 (Div. 2) A题和B题的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-05-09flutter3.x_macos桌面os实战
- 2024-05-09Rust中的并发性:Sync 和 Send Traits
- 2024-05-08使用Ollama和OpenWebUI在CPU上玩转Meta Llama3-8B
- 2024-05-08完工标准(DoD)与验收条件(AC)究竟有什么不同?
- 2024-05-084万 star 的 NocoDB 在 sealos 上一键起,轻松把数据库编程智能表格
- 2024-05-08Mac 版Stable Diffusion WebUI的安装
- 2024-05-08解锁CodeGeeX智能问答中3项独有的隐藏技能
- 2024-05-08RAG算法优化+新增代码仓库支持,CodeGeeX的@repo功能效果提升
- 2024-05-08代码报错不用愁,CodeGeeX一键完成代码修复、错误解释的功能上线了!
- 2024-05-08今天开始程序员不用再发愁写commit message了,全部由CodeGeeX自动完成!