A a healthy breakfast
问题:

思路:扫描给定字符串,看M和R哪个先出现
代码:
#include <iostream>
using namespace std;
int main() {
    int cnt = 0;
    string str;
    cin >> str;
    for(auto t: str) {
        if(t == 'R') {
            cout << "Yes";
            return 0;
        } else if(t == 'M') {
            cout << "No";
            return 0;
        }
    }
    return 0; 
} 
B vertical reading
问题:

思路:三层循环,第一层循环枚举w,第二层循环枚举w个字母中的第i位,第三层循环枚举被划分后的每个字符串的第i位
代码:
#include <bits/stdc++.h>
using namespace std;
int main() {
    string a, b;
    cin >> a >> b;
    
    int n = max(a.size(), b.size());
    for(int i = 1; i < n; i ++ ) {
        for(int k = 1; k <= i; k ++ ) {
            string str;
            for(int j = k; j <= a.size(); j += i ) {
                str += a[j - 1];
            }
            if(str == b) {
                cout << "Yes";
                return 0;
            }
        }
    }
    cout << "No" << endl;
    return 0;
} 
C Move it
问题:

思路:输出所有装有至少2个物品的盒子中除了最大质量的物品其余物品的质量和
代码:
#include <bits/stdc++.h>
using namespace std;
int main() {
    int n;
    cin >> n;
    vector<int> a(n + 1);
    vector<int> w(n + 1);
    for(int i = 1; i <= n; i ++ ) cin >> a[i];
    for(int i = 1; i <= n; i ++ ) cin >> w[i];
    vector<vector<int>> q((n + 1));
    for(int i = 1; i <= n; i ++ ) {
        q[a[i]].push_back(w[i]);
    }
    long long ans = 0;
    for(int i = 1; i <= n; i ++ ) {
        sort(q[i].begin(), q[i].end());
        if(q[i].size() > 1) {
            for(int j = 0; j < q[i].size() - 1; j ++ ) ans += q[i][j];
        }
    }
    cout << ans;
    return 0;
} 
D ghost ants
问题:

思路:
将向左移动的蚂蚁视作静止,同时向右移动的蚂蚁每个单位时间移动2个单位长度
将向左移动的蚂蚁与向右移动的蚂蚁分开存储
对向左移动的蚂蚁排序
枚举向右移动的蚂蚁x
开始二分:
第一个二分找到向左移动的蚂蚁中第一个坐标大于等于x蚂蚁的坐标,如果找不到,则说明x不会对答案有贡献,直接continue,反之如果找到了,那么开始第二个二分,第二个二分查找的是最后一个小于等于 x蚂蚁的坐标 y 加上 2 * T的蚂蚁
代码:
#include <bits/stdc++.h>
using namespace std;
int main() {
    int n, T;
    cin >> n >> T;
    vector<char> str(n + 1);
    for(int i = 1; i <= n; i ++ ) cin >> str[i];
    vector<long long> fl, fr;
    fl.push_back(0);
    fr.push_back(0);
    for(int i = 1; i <= n; i ++ ) {
        int x;
        cin >> x;
        if(str[i] == '0') fl.push_back(x);
        else fr.push_back(x);
    }
    
    sort(fl.begin() + 1, fl.end());
    long long ans = 0;    
    for(int i = 1; i <= fr.size() - 1; i ++ ) {
        int l = 1, r = fl.size() - 1;
        long long x = fr[i];
        while(l < r) {
            int mid = l + r >> 1;
            if(x <= fl[mid]) r = mid;
            else l = mid + 1;
        }
        if(x > fl[l]) continue;
        x += 2 * T;
        int tmp = l;
        r = fl.size() - 1;
        while(l < r) {
            int mid = l + r + 1 >> 1;
            if(x >= fl[mid]) l = mid;
            else r = mid - 1;
        }
        if(x >= fl[l]) ans += l - tmp + 1;
    }
    cout << ans;
    return 0;
} 
                ![ABAP 新语法-ITAB[ idx ]、ITAB[ key ]](https://img-blog.csdnimg.cn/direct/6283aaaf93794670bf9a69ec63064bf3.png)


















