Codeforces Round #715 (Div. 2) A题和B题

Codeforces Round #715 (Div. 2) A题和B题

传送门:A题

题目大意:N个整数代表身高,为了让数组中前后两个数的平均值都尽可能为整数,输出满足条件的数组。

思路分析:直接把数组中的奇数放在左边,偶数放在右边即可。

Codeforces Round #715 (Div. 2) A题和B题
#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。

Codeforces Round #715 (Div. 2) A题和B题
#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

 

上一篇:运营商的ICT转型路(一)


下一篇:复包络及复信号的简单回顾