Hottest 30 of codeforce

1. 4A.Watermelon

题目链接:https // s.com/problemset/problem/4/A

题意:两人分瓜,但每一部分都得是偶数

分析:直接 对2取余,且 w != 2

#include<bits/stdc++.h>
using namespace std;
int main() {
    int n;
    cin >> n;
    if (n % 2 == 0 && n != 2)cout << "YES\n";
    else cout << "NO" << endl;
    return 0;
}

2. 1A.Theatre Square

题目链接:https // s.com/problemset/problem/1/A

题意:铺地板,给定边长为a的正方形砖块。允许铺的面积大于广场面积

分析:注意数据很大 用__int64 存储,向上取整$ (n + a - 1) / a $

#include <iostream>
using namespace std;
int main() {
    __int64 a, n, m;
    cin >> n >> m >> a;
    cout << ((n + a - 1) / a) * ((m + a - 1) / a) << endl;
    return 0;
}

3. 71A.Way Too Long Words

题目链接:https // s.com/problemset/problem/71/A

题意:如果字符串长度大于10则需要压缩长度

分析:水题

#include<bits/stdc++.h>
using namespace std;
int main() {
    string s;
    int n;
    cin >> n;
    while (n--) {
        cin >> s;
        int len = s.length();
        if (len > 10) cout << s[0] << len - 2 << s[len - 1] << endl;
        else cout << s << endl;
    }
    return 0;
}

4. 158A.Next Round

题目链接:https // s.com/problemset/problem/158/A

题目描述:题意很简单,要求按照大小顺序输入n个数据并判断大于第k个数据的非零数字个数

#include<bits/stdc++.h>
using namespace std;
int main() {
    int n, k, c = 0, t, a[51]; 
    cin >> n >> k;
    for (int i = 0; i < n; i++)
        cin >> a[i];
    for (int i = 0; i < n; i++)
        if (a[i] >= a[k - 1] && a[i] > 0)
            c++;
    cout << c << '\n';
    return 0;
}

5. 231A. Team

题目链接:https // s.com/problemset/problem/231/A

#include<bits/stdc++.h>
using namespace std;
int main() {
    int n, a, b, c, cnt = 0;
    for (scanf("%d", &n); n; --n) {
        scanf("%d %d %d", &a, &b, &c); if (a + b + c >= 2)++cnt;
    }
    cout << cnt << endl;
    return 0;
}

6. 118A.String Task

题目链接:https // s.com/problemset/problem/118/A

题目描述:输入一串字符,如果英文字母是大写则转换为小写,是元音则去掉,是辅音则在前加“.”,输出处理后的字母。

分析:先判断字符串种是否为英文字母,然后将大写转换为小写,利用第二个字符串,是元音则跳过,是辅音则先加“.”再加上辅音字母,最后输出处理后的字符串。

#include<bits/stdc++.h>
using namespace std;
int main() {
    char s;
    while (cin >> s) {
        s = tolower(s);
        if (!(s == 'e' || s == 'a' || s == 'y' || s == 'u' || s == 'o' || s == 'i')) { cout << "." << s; }
    }
    cout << endl;
    return 0;
}

7. 50A.Domino piling

题目链接:https // s.com/problemset/problem/50/A

#include<bits/stdc++.h>
using namespace std;
int n, m;
int main() {
    cin >> n >> m;
    cout << ((n * m) >> 1) << endl;
    return 0;
}

8. 282A.Bit++

题目链接:https // s.com/problemset/problem/282/A

#include <iostream>
#include <string>
#define LL long long
using namespace std;
int main()
{
    string str;
    LL x = 0 , n, a;
    cin >> n;
    for (a = 1; a <= n; a++)
    {
        cin >> str;
        if (str == "++X" || str == "X++")
            x++;
        else x--;
    }
    cout << x;
    return 0;

}

9. 112A.Petya and Strings

题目链接:https // s.com/problemset/problem/112/A

分析:比较字符串,两个字符串都变为小写,然后通过str自带的字典序比较输出结果

#include<bits/stdc++.h>
using namespace std;
string s1, s2;
int main() {
    cin >> s1 >> s2;
    for (auto& p    s1)p = tolower(p);
    for (auto& p    s2)p = tolower(p);
    if (s1 > s2)cout << 1;
    else if (s1 == s2)cout << 0;
    else cout << -1;
    return 0;
}

10. 263A.Beautiful Matrix

题目链接:https // s.com/problemset/problem/263/A

分析:找到唯一的1,计算坐标到中心的距离即 $ abs(i - 3) + abs(j - 3) $

#include<bits/stdc++.h>
using namespace std;
int main(){
    int ans, a;
    for (int i = 1; i <= 5; i++)
        for (int j = 1; j <= 5; j++){
            cin >> a;
            if (a == 1) { ans = abs(i - 3) + abs(j - 3); break; }
        }
    cout << ans;
    return 0;
}

11 339A - Helpful Maths

#include<bits/stdc++.h>
using namespace std;
int main() {
    string s;
    cin >> s;
    sort(s.begin(), s.end());
    int len = s.length();
    if (len == 1)cout << s;
    else {
        for (int i = len / 2; i < len; ++i)
            if (i != s.length() - 1)cout << s[i] << "+";
            else cout << s[i];
    }
    return 0;
}

看dalao题解的时候发现了一个cin函数 - cin.ignore() [讲解](https //blog.csdn.net/qq_36274515/article/details/77714152)

#include <bits/stdc++.h>
using namespace std;
int main(){
	int a[100],i=0,j;
	while(cin>>a[i++])cin.ignore(1);//读入数字后ignore +
	sort(a,a+--i);
	for(j=0;j<i;j++){cout<<a[j];if(j<i-1)cout<<'+';}
    return 0;
}

12. 281A - Word Capitalization

#include<bits/stdc++.h>
using namespace std;
int main() {
    string s;
    cin >> s;
    s[0] = toupper(s[0]);
    cout << s;
    return 0;
}

13. 96A - Football

字符串查找:find函数,这里有个技巧,find返回值为 size_type 如果在字符串中未找到即返回npos4294967295)== -1 ,而找到了就会返回下标。

#include<bits/stdc++.h>
using namespace std;
int main() {
    string s1 = "1111111", s2 = "0000000", s;
    cin >> s;
    //令返回值 +1 , -1 -> 0 or 下标变为正数 再配合 || 即可判断
    printf("%s", s.find(s1) + 1 || s.find(s2) + 1 ? "YES"    "NO");
    return 0;
}
//当然正常写法也是可以的利用for循环

14. 266A - Stones on the Table

#include <bits/stdc++.h>
using namespace std;
int main() {
    char a, b; int c = 0,t;
    cin >> t >> a;    //不断读入并比较
    while (t--) { b = getchar(); a == b ? c++ : a = b; }
    cout << c << endl;
}

15. 236A - Boy or Girl

#include<bits/stdc++.h>
using namespace std;
int main() {
    string s; set<char>_set;
    cin >> s;
    for (auto c : s)_set.insert(c);
    if (_set.size() % 2 == 0)cout << "CHAT WITH HER!";
    else cout << "IGNORE HIM!";
    return 0;
}

优化

#include<bits/stdc++.h>
using namespace std;
int main() {
    char ch; string s;
    while (cin >> ch) if (s.find(ch) == -1) s += ch;
    if (s.size() % 2 == 0) cout << "CHAT WITH HER!";
    else cout << "IGNORE HIM!";
}

16. 69A - Young Physicist

#include<bits/stdc++.h>
using namespace std;
int n, a, b, c, x, y, z;
int main() {
    cin >> n;
    while (n--) { cin >> a >> b >> c; x += a, y += b, z += c; }
    if (x == 0 &&  y == 0 &&  z == 0)cout << "YES";
    else cout << "NO";
    return 0;
} 

17. 122A - Lucky Division

//根据题意发现是对一些数是否除尽
#include<bits/stdc++.h>
using namespace std;
int main() {
    int n;
    cin >> n;
    cout << (n % 4 == 0 || n % 7 == 0 || n % 47 == 0 || n % 74 == 0 || n % 477 == 0 ? "YES" : "NO");
    return 0;
}

18. 58A - Chat room

#include<bits/stdc++.h>
using namespace std;
int main(){
    string s, A = "hello"; int i = 0;
    cin >> s;
    for (auto c : s)if (c == A[i])++i;
    if (i == 5)cout << "YES";
    else cout << "NO";
}

19. 546A - Soldier and Bananas

#include<bits/stdc++.h>
using namespace std;
int main() {
    long long n, k, w, t;
    cin >> k >> n >> w;
    t = (1 + w) * w * k / 2;
    if (n >= t)cout << 0;
    else cout << t - n;
    return 0;
}

20. 116A - Tram

#include<bits/stdc++.h>
using namespace std;
int main() {
    int n, a, b, Max = 0,t = 0; cin >> n;
    while (n--) { cin >> a >> b; t += b - a; Max = max(Max, t); }
    cout << Max;
    return 0;
}

21. 791A - Bear and Big Brother

#include<bits/stdc++.h>
using namespace std;
int main(){
    int a, b, t = 0; cin >> a >> b;
    while (a <= b) { a *= 3, b *= 2; ++t; }
    cout << t;
    return 0;
}

22. 160A - Twins

#include<bits/stdc++.h>
using namespace std;
int main(){
    int t, n = 0, h = 0, i, j, a[105];
    cin >> t;
    for (i = 0; i < t; i++){
        cin >> a[i];
        h += a[i];
    }
    sort(a, a + t);
    for (i = 0; 2 * n <= h; i++) n += a[t - i - 1];
    cout << i << endl;
}

23. 977A.Wrong Subtraction

#include<bits/stdc++.h>
using namespace std;
int main() {
    __int64 n; int k;cin >> n >> k;
    while (k--) if (n % 10 == 0)n /= 10; else n--;
    cout << n;
    return 0;
}

24.617A.Elephant

#include<bits/stdc++.h>
using namespace std;
int main() {
    __int64 n; cin >> n;
    cout << (n + 4) / 5;
    return 0;
}

25. 133A. HQ9+

#include<bits/stdc++.h>
using namespace std;
int main() {
    string s; bool flag = false; cin >> s;
    for (auto c : s)if (c == 'H' || c == 'Q' || c == '9') { flag = true; break; }
    if (flag)cout << "YES";
    else cout << "NO";
    return 0;
}

26. 158B - Taxi

#include <iostream>
#include <algorithm>
using namespace std;
int main(){
    int n;
    while (cin >> n){
        int a[5] = { 0 }, cnt,sum = 0;
        while(cin >> cnt)a[cnt]++;
        for (int i = 4; i >= 1; i--){
            if (i == 4)
                sum += a[i];
            else if (i == 3){
                sum += a[3];
                a[1] -= min(a[3], a[1]);
            }
            else if (i == 2){
                sum += a[2] / 2;
                if (a[2] % 2 == 0)
                    a[2] = 0;
                else{
                    a[2] = 1;
                    a[1] -= 2;
                    sum++;
                }
            }
            else{
                if (a[1] > 0){
                    if (a[1] % 4 == 0)
                        sum += a[1] / 4;
                    else sum += a[1] / 4 + 1;
                }
            }
        }
        cout << sum << endl;
    }
    return 0;
}

转化为数论解法

#include<iostream>
#include<algorithm>
using namespace std;
int A[5], N,  t;
int main() {
    cin >> N; while (std::cin >> t)A[t]++;
    A[1] = max(A[1] - A[3], 0);
    cout << A[3] + A[4] + (A[1] + 2 * A[2] + 3) / 4;
    return 0;
}

27. 266B - Queue at the School

#include<bits/stdc++.h>
using namespace std;
int main() {
    string s; int n, m;
    cin >> n >> m >> s;
    while (m--) for (int i = 0; i < n - 1; ++i)if (s[i] == 'B' && s[i + 1] == 'G') { swap(s[i], s[i + 1]); ++i; }
    cout << s;
    return 0;
}

28. 110A - Nearly Lucky Number

#include<bits/stdc++.h>
using namespace std;
int main() {
    string s; int i = 0; cin >> s;
    for (auto c : s)i += (c == '4' || c == '7');
    if (i == 4 || i == 7)cout << "YES";
    else cout << "NO";
    return 0;
}

29. 41A - Translation

#include<bits/stdc++.h>
using namespace std;
int main() {
    string s, ss; cin >> s >> ss;
    int len = s.length();
    for (int i = 0; i < len; ++i)if (s[i] != ss[len - i - 1]) { cout << "NO"; return 0; }
    cout << "YES";
    return 0;
}

30. 59A - Word

#include <bits/stdc++.h>
using namespace std;
int main(){
    string s; cin >> s;
    int uc = 0, lc = 0;
    for (char c : s)(isupper(c) ? uc : lc)++;
    for (char c : s) cout << char(lc >= uc ? tolower(c) : toupper(c));
    return 0;
}
posted @ 2020-06-05 19:53  RioTian  阅读(237)  评论(0编辑  收藏  举报