Mynavi Programming Contest 2021(AtCoder Beginner Contest 201)A ~ E题题解
A - Tiny Arithmetic Sequence
水题,判断3个数是否能构成等差数列
void solve() {
int a, b, c;
cin >> a >> b >> c;
if (a + b == 2 * c || a + c == 2 * b
|| b + c == 2 * a)cout << "Yes\n";
else cout << "No\n";
}
B - Do you know the second highest mountain?
排序,先按山脉高度排序,高度一样则按名字排序
struct node {
string s; int t;
};
vector<node>v;
bool cmp(node a, node b) {
if (a.t == b.t)return a.s > b.s;
return a.t > b.t;
}
void solve() {
int n;
cin >> n;
for (int i = 0; i < n; ++i) {
string s; int t;
cin >> s >> t;
v.push_back({s, t});
}
sort(v.begin(), v.end(), cmp);
cout << v[1].s << '\n';
}
赛后发现自己写复杂化了
pair<int, string>a[1010];
void solve() {
int n;
cin >> n;
for (int i = 1; i <= n; ++i)cin >> a[i].second >> a[i].first;
sort(a + 1, a + 1 + n);
cout << a[n - 1].second << endl;
}
C - Secret Number
这道题,是检测 0000 ~ 9999 的每一个值,但我们可以通过高桥的字符串进行简化
void solve() {
string s; cin >> s;
int ans = 0;
for (int i = 0; i <= 9999; ++i) {
vector<bool> f(10);
int x = i;
for (int j = 0; j < 4; ++j) {
f[x % 10] = true;
x /= 10;
}
bool f2 = true;
for (int j = 0; j < 10; ++j) {
if (s[j] == 'o' and !f[j]) f2 = false;
if (s[j] == 'x' and f[j]) f2 = false;
}
ans += f2;
}
cout << ans << '\n';
}
S = input()
ans = 0
for i in range(10000):
flag = [False]*10
now = i
for j in range(4):
flag[now%10] = True
now //= 10
flag2 = True
for j in range(10):
if S[j] == 'o' and not flag[j]:
flag2 = False
if S[j] == 'x' and flag[j]:
flag2 = False
ans += flag2
print(ans)
D - Game in Momotetsu World
虽然正向搜索会很麻烦,但反过来从终点搜索起点使用DP记录即可
using ll = long long;
ll n, m, dp[2010][2010];
char s[2011][2011];
void solve() {
scanf("%lld%lld", &n, &m);
for (int i = 1; i <= n; i++)
scanf("%s", s[i] + 1);
memset(dp, 63, sizeof(dp));
dp[n][m] = 0;
for (int i = n; i > 0; i--)
for (int j = m; j > 0; j--) {
if (i == n && j == m)
continue;
dp[i][j] = max((s[i + 1][j] == '+' ? 1 : -1) - dp[i + 1][j],
(s[i][j + 1] == '+' ? 1 : -1) - dp[i][j + 1]);
}
if (dp[1][1] > 0)cout << "Takahashi\n";
else if (dp[1][1] == 0)cout << "Draw\n";
else cout << "Aoki\n";
}
E - Xor Distances
#include<bits/stdc++.h>
#define int long long
#define N 200005
#define MOD 1000000007
using namespace std;
int n, d[N], ans;
vector<int> to[N], w[N];
void add(int u, int v, int wt) {to[u].push_back(v), w[u].push_back(wt);}
void dfs(int u, int fa) {
for (int i = 0, v; i < to[u].size(); i++)
if ((v = to[u][i]) != fa)d[v] = d[u] ^ w[u][i], dfs(v, u);
}
signed main() {
cin >> n;
for (int i = 1, u, v, wt; i < n;
i++)scanf("%lld%lld%lld", &u, &v, &wt), add(u, v, wt), add(v, u, wt);
dfs(1, 0);
for (int k = 0; k < 60; k++) {
int a = 0;
for (int i = 1; i <= n; i++)a += ((d[i] >> k) & 1);
ans = (ans + a * (n - a) % MOD * ((1ll << k) % MOD) % MOD) % MOD;
}
cout << ans << endl;
return 0;
}
F - Insertion Sort
待补
Mynavi Programming Contest 2021(AtCoder Beginner Contest 201)A ~ E题题解的更多相关文章
- M-SOLUTIONS Programming Contest 2021(AtCoder Beginner Contest 232) 题解
目录 G - Modulo Shortest Path H - King's Tour 因为偷懒就只写G和H的题解了. G - Modulo Shortest Path 首先可以观察到对于一条从点\( ...
- AtCoder Beginner Contest 076
A - Rating Goal Time limit : 2sec / Memory limit : 256MB Score : 100 points Problem Statement Takaha ...
- atcoder beginner contest 251(D-E)
Tasks - Panasonic Programming Contest 2022(AtCoder Beginner Contest 251)\ D - At Most 3 (Contestant ...
- AtCoder Beginner Contest 100 2018/06/16
A - Happy Birthday! Time limit : 2sec / Memory limit : 1000MB Score: 100 points Problem Statement E8 ...
- KYOCERA Programming Contest 2021(AtCoder Beginner Contest 200) 题解
KYOCERA Programming Contest 2021(AtCoder Beginner Contest 200) 题解 哦淦我已经菜到被ABC吊打了. A - Century 首先把当前年 ...
- AtCoder Beginner Contest 184 题解
AtCoder Beginner Contest 184 题解 目录 AtCoder Beginner Contest 184 题解 A - Determinant B - Quizzes C - S ...
- AtCoder Beginner Contest 255(E-F)
Aising Programming Contest 2022(AtCoder Beginner Contest 255) - AtCoder E - Lucky Numbers 题意: 给两个数组a ...
- AtCoder Beginner Contest 052
没看到Beginner,然后就做啊做,发现A,B太简单了...然后想想做完算了..没想到C卡了一下,然后还是做出来了.D的话瞎想了一下,然后感觉也没问题.假装all kill.2333 AtCoder ...
- AtCoder Beginner Contest 053 ABCD题
A - ABC/ARC Time limit : 2sec / Memory limit : 256MB Score : 100 points Problem Statement Smeke has ...
- AtCoder Beginner Contest 136
AtCoder Beginner Contest 136 题目链接 A - +-x 直接取\(max\)即可. Code #include <bits/stdc++.h> using na ...
随机推荐
- 🔥🔥Java开发者的Python快速实战指南:探索向量数据库之文本搜索
前言 如果说Python是跟随我的步伐学习的话,我觉得我在日常开发方面已经没有太大的问题了.然而,由于我没有Python开发经验,我思考着应该写些什么内容.我回想起学习Java时的学习路线,直接操作数 ...
- 【Codeforces Global Round 12】 C2 - Errich-Tac-Toe题解(思维)
题面 题目要求不能有有三个连续相同的'X'或'O',注意到这样的连续串它们的横纵坐标之和是连续变化的,考虑将它们按照横纵坐标之和对 \(3\)的模值分组,因为这样分组后相邻的三个相同字符就被分到了三个 ...
- Chrome扩展的核心:manifest 文件(下)
大家好,我是 dom 哥.这是我关于 Chrome 扩展开发的系列文章,感兴趣的可以 点个小星星. 在上篇和中篇中已经完成了对 manifest 文件中以下字段的解释: "manifest_ ...
- yarn的常用命令
yarn 安装 npm install -g yarn 查看版本 yarn -v 开始一个新工程 yarn init 与 npm init 一样通过交互式会话创建一个 package.json yar ...
- ElasticSearch之Slow Log
ElasticSearch的慢日志,相关的参数及配置方法. 在log4j2.properties中配置慢日志的输出文件名. Search Slow Log 相关参数 index.search.slow ...
- 【经典问题】mysql和redis数据一致性问题
前言 MySQL和Redis数据一致性算是个很经典的问题,在之前也看到过很多相关的文章,最近心血来潮,想把一致性问题的解决方案和存在问题都总结一下. 不推荐方案 1 先更新MySQL,再更新Redis ...
- Python——第一章:注释、变量、常量
python中的注释有2种: 1.单行注释 单行注释用# #这是一个单行注释 快捷键用Ctrl+/全选多个内容可以多行快速注释,也可以快速去掉注释符# 比如快速将全选的所有行注释掉--加# 2.多行注 ...
- 标注工具合集(点云&图片)
有什么问题欢迎留言交流,发现好用的会持续更新-- 图片类 1. labelimg:https://github.com/tzutalin/labelImg --- 只能拉框 2. labelme:ht ...
- 文心一言 VS 讯飞星火 VS chatgpt (44)-- 算法导论6.1 1题
一.在高度为h的堆中,元素个数最多和最少分别是多少? 文心一言: 在高度为 h 的二叉搜索树(BST)中,元素个数最多和最少的情况分别如下: 1.最多情况:当每个节点都包含两个子节点时,BST 中的元 ...
- 深入了解RC4 Drop加密技术
一.引言 在网络安全领域,加密技术始终是重中之重.随着计算机技术的发展,加密算法也在不断更新换代.RC4(Rivest Cipher 4)加密算法因其高效.简洁的特性,在信息安全领域得到了广泛的应用. ...