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; } }
传送门: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; } }