AtCoder Beginner Contest 235 A~F

A - Rotate

按照题目指示做

int main() {
    ios::sync_with_stdio(false);
    cin.tie(nullptr);
    char a, b, c; cin >> a >> b >> c;
    int x1 = a-'0', x2 = b-'0', x3 = c-'0';
    cout << x1*100+x2*10+x3 + x2*100+x3*10+x1 + x3*100+x1*10+x2 << endl;
}

B - Climbing Takahashi

找到一直递增的尽头

int main() {
    ios::sync_with_stdio(false);
    cin.tie(nullptr);
    int n; cin >> n;
    vector<int> a(n+1);
    for (int i = 1; i <= n; i++) cin >> a[i];
    int now = a[1];
    for (int i = 2; i <= n; i++) {
        if (a[i] > a[i-1]) {
            now = a[i];
        } else {
            break;
        }
    }
    cout << now << endl;
}

C - The Kth Time Query

寻找x在数列中第k次出现,用map存一下然后O(1)找

map<int, vector<int>> mp;
int main() {
    ios::sync_with_stdio(false);
    cin.tie(nullptr);
    int n, q; cin >> n >> q;
    for (int i = 1; i <= n; i++) {
        int x;
        cin >> x;
        mp[x].push_back(i);
    }
    while(q--) {
        int x, k; cin >> x >> k;
        if (k > mp[x].size()) cout << -1 << endl;
        else cout << mp[x][k-1] << endl;
    }
}

D - Multiply and Rotate

用bfs暴力找一下就可以了

struct node {
    int now, step;
};
int vis[N];
int base[7];
int main() {
    ios::sync_with_stdio(false);
    cin.tie(nullptr);
    base[0] = 1;
    for (int i = 1; i <= 6; i++) base[i] = base[i-1] * 10;
    int a, n; cin >> a >> n;
    queue<node> que;
    que.push({1, 0});
    while (que.size()) {
        node now = que.front();
        que.pop();
        if (now.now == n) {
            cout << now.step << endl;
            return 0;
        }
        if (vis[now.now]) continue;
        vis[now.now] = 1;
        if (1ll*now.now*a<=3e6 && !vis[now.now*a]) que.push({now.now*a, now.step+1});
        if (now.now % 10 == 0) continue;
        int tmp = now.now;
        int dig = 0;
        while (tmp) {
            tmp /= 10;
            dig++;
        }
        int ttmp = now.now%10*base[dig-1] + now.now/10;
        if (ttmp<=3e6 && !vis[ttmp]) que.push({ttmp, now.step+1});
    }
    cout << -1 << endl;
}

E - MST + 1

最小生成树问题,考虑离线处理,将询问全部丢到边集里面,在构建最小生成树时check一下是否在树内

#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
const int N = 3e6 + 10;
const int mod = 998244353;
struct Edge {
    int state, u, v, w;
    bool operator < (const Edge &rhs) const {
        return w < rhs.w;
    }
}e[N];
int fa[N], ans[N];
int find(int x) {return x == fa[x] ? x : fa[x] = find(fa[x]);}
int main() {
    ios::sync_with_stdio(false);
    cin.tie(nullptr);
    int n, m, q; cin >> n >> m >> q;
    for (int i = 1; i <= m; i++) {
        cin >> e[i].u >> e[i].v >> e[i].w;
        e[i].state = 0;
    }
    for (int i = m+1; i <= m+q; i++) {
        cin >> e[i].u >> e[i].v >> e[i].w;
        e[i].state = i - m;
    }
    for (int i = 1; i <= m+q; i++) fa[i] = i;
    sort(e+1, e+m+q+1);
    int count = 0;
    for (int i = 1; i <= m + q; i++) {
        int u = find(e[i].u);
        int v = find(e[i].v);
        if (u != v) {
            if (!e[i].state) {
                count++;
                fa[u] = v;
                if (count == n - 1) break;
            } else {
                ans[e[i].state] = 1;
            }
        }
    }
    for (int i = 1; i <= q; i++) {
        if (ans[i]) cout << "Yes" << endl;
        else cout << "No" << endl;
    }
}

F - Variety of Digits

简单的数位DP,记 d p [ p o s ] [ s t a t e ] dp[pos][state] dp[pos][state]为当前在pos位且取到数字的状压表示为state的个数,dp2[pos][state]为和

在数位DP中分类讨论一下,如果是前导0,那么不会记录state中

#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
const int N = 3e6 + 10;
const int mod = 998244353;
typedef pair<ll, ll> pii;
ll dp[10005][2048];
ll dp2[10005][2048];
int a[10005], st;
ll base[10005];
pii dfs(int pos, int state, bool limit, bool lead) {
    if (pos == -1) {
        if ((state & st) == st) return {1,0};
        else return {0,0};
    }
    if (!limit && !lead && dp[pos][state] != -1) return {dp[pos][state], dp2[pos][state]};
    int End = limit ? a[pos] : 9;
    ll ans1 = 0, ans2 = 0;
    for (int i = 0; i <= End; i++) {
        if (lead) {
            if (i == 0) {
                pii tmp = dfs(pos-1, state, limit && i == End, 1);
                ans1 = (ans1 + tmp.first) % mod;
                ans2 = (ans2 + i * base[pos] % mod * tmp.first % mod + tmp.second) % mod;
            }
            else {
                pii tmp = dfs(pos-1, state | (1<<i), limit && i == End, 0);
                ans1 = (ans1 + tmp.first) % mod;
                ans2 = (ans2 + i * base[pos] % mod * tmp.first % mod + tmp.second) % mod;
            }
        } else {
            pii tmp = dfs(pos-1, state | (1 << i), limit && i == End, 0);
            ans1 = (ans1 + tmp.first) % mod;
            ans2 = (ans2 + i * base[pos] % mod * tmp.first % mod + tmp.second) % mod;
        }
    }
    if (!limit && !lead) dp[pos][state] = ans1, dp2[pos][state] = ans2;
    return {ans1, ans2};
}

int main() {
    ios::sync_with_stdio(false);
    cin.tie(nullptr);
    base[0] = 1;
    for (int i = 1; i <= 10000; i++) base[i] = base[i-1] * 10 % mod;
    string s; cin >> s;
    int len = s.size();
    int m; cin >> m;
    for (int i = 1; i <= m; i++) {
        int x; cin >> x;
        st |= 1 << x;
    }

    for (int i = 0; i < s.size(); i++) a[i] = s[len-1-i]-'0';
    memset(dp, -1, sizeof dp);
    memset(dp2, -1, sizeof dp2);
    cout << dfs(len-1, 0, true, true).second << endl;
}

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答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 是一个对于新手非常友好的比赛,它提供了一个锻炼和展示编程技能的平台。无论是对于新手还是更有经验的选手,参加这样的比赛都是一个宝贵的机会。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值