atcoder abc 360

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;
}

  • 10
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: atcoder beginner contest 235 是一场由 AtCoder 组织的初学者比赛,旨在为初学者提供一个锻炼自己编程能力的平台。比赛通常包括多个问题,参赛者需要在规定时间内解决这些问题。比赛难度逐渐增加,从而帮助参赛者提高自己的编程技能。 ### 回答2: ATCoder Beginner Contest 235(简称ABC 235)是一项由ATCoder举办的编程竞赛。该比赛旨在为初学者提供一个机会展示他们的编程技巧和解决问题的能力。 ABC 235通常由4个问题组成,题目难度递增。参赛者需要在规定的时间内使用编程语言解决这些问题。这些问题通常涵盖了各种编程相关的主题,例如数学问题、字符串处理、排序和搜索算法等。 在比赛开始前,参赛者将获得一份题目说明文档和输入样例。他们需要根据题目要求编写程序,处理给定的输入数据,并生成相应的输出。比赛时间一般为2-3小时,参赛者需要尽可能快速且准确地解决问题。 评判将根据参赛者的程序输出与预期结果的一致性进行。参赛者可以在比赛过程中提交多次解答,但只有第一次正确答案会被记入最终的成绩。 ABC 235不仅提供了一个竞赛平台,还鼓励参赛者通过讨论和分享解题思路来学习和提高。在比赛结束后,ATCoder将提供详细的解题分析和解题报告,帮助参赛者了解每个题目的最佳解决方法,并提供参考答案和示例代码。 通过参加ATCoder Beginner Contest 235,参赛者可以提升他们的编程技能,锻炼逻辑思维能力,并与全球的编程爱好者交流。无论是初学者还是有经验的编程者,ABC 235都是一个很好的学习和挑战的机会。 ### 回答3: AtCoder Beginner Contest 235 是一个在 AtCoder 上的初级比赛。该比赛通常会吸引很多新手程序员参加。它由 AtCoder 组织主办,旨在帮助新手提高编程技能以及在竞赛中锻炼自己。 比赛的题目难度由易到难,共有四个问题。通常,第一个问题是一个简单的数学问题,要求解决一个简单的算术运算。第二个问题可能是一个字符串操作问题,需要对给定的字符串进行处理。第三个问题可能是一个动态规划或贪心算法问题,需要细心分析问题,找出最优解。最后一个问题通常是一个较难的图论或组合问题,需要一些高级算法来解决。 参赛选手在比赛开始后有一定的时间限制来解决这些问题。他们可以使用自己熟悉的编程语言来实现解决方案。然后他们将自己的程序提交到 AtCoder 的在线评测系统中进行评测。评测结果会即时显示,并将参赛选手的成绩排名和讨论解答过程的视频分享给其他选手。 参加 AtCoder Beginner Contest 235 对于新手来说是一个很好的机会。通过解决这些问题,他们可以练习编程技巧,提高解决问题的能力。比赛结束后,他们还可以看到其他选手的解答,学习他们的思路和方法。同时,比赛的排名和奖励也是一种鼓励和激励新手继续努力学习的方式。 总之,AtCoder Beginner Contest 235 是一个对于新手非常友好的比赛,它提供了一个锻炼和展示编程技能的平台。无论是对于新手还是更有经验的选手,参加这样的比赛都是一个宝贵的机会。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值