Codeforces Round #104 (Div.2)

比赛链接:https://codeforces.com/contest/146

题目:A. Lucky Ticket

样例1:

输入:

2
47

输出

NO

解释:只需要判断这个字符串的0 - n / 2 - 1 是否和n / 2 到n - 1的相等就可以了,并且这两个字符串中不能出现除了4,7以外的数字

#include<bits/stdc++.h>
using namespace std;
typedef long long LL;
const int N = 1100;

int main()
{
    int n;
    string str;
    int a = 0,b = 0;
    cin >> n;
    cin >> str;
    
    for(int i = 0;i < n / 2;i ++){
        if(str[i] != '4' && str[i] != '7'){
            cout << "NO" << endl;
            return 0;
        }
        a += (str[i] - '0');
    }
    for(int i = n / 2;i < n;i ++){
        if(str[i] != '4' && str[i] != '7'){
            cout << "NO" << endl;
            return 0;
        }
        b += str[i] - '0';
    }
    
    if(a == b){
        cout << "YES" << endl;
    }else{
        cout << "NO" << endl;
    }
    
	return 0;
}

题目:B. Lucky Mask

样例1:

输入:

1 7

输出

7

解释:找到第一个比a大的是,并且这个字符串删除掉没用的数字后的幸运数为b;
这就是一个纯模拟题,按照题的思路做就好了

知足常乐!
原文地址:https://www.cnblogs.com/yjsh/p/14155523.html