AtCoder Beginner Contest 198 个人题解(AB水题,C思维,D思维+全排列,E题DFS搜索,F懵逼)
补题链接:Here
A - Div
题意:N 个不一样的糖,请问有多少种分法给 A,B两人
水题,写几组情况就能知道输出
B - Palindrome with leading zeros
题意:给定一个字符串,问是否可以在字符串前加若干个 0
使字符串回文
先判断一下字符串回文否?本身就回文就无需处理,不然字符串后面有几个 0
就加上多少,然后再判断
C - Compass Walking
题意:在一个二维坐标轴上,给定一个长度 R
,请问是否有最小步数(每步只能走 R,但坐标可以非整数)到达
思路:
假设
- 答案为
,如果 - 答案为
,如果 并且 ,其他情况
其实这里 第一种情况和第三种情况可合并写:
ceil(d / R)
void solve() {
double R, X, Y;
cin >> R >> X >> Y;
double d = sqrt(X * X + Y * Y);
if (d < R) cout << 2;
else
cout << ceil(d / R);
}
D - Send More Money
题意:给定
思路:
首先,如果出现 UNSOLVABLE
即可
对于剩下的情况来说,可以尝试把数字分配给字母,然后 check 一下
注意别给首位分配
即可
void solve() {
map<char, int> ch;
string s, t, w;
cin >> s >> t >> w;
for (char c : s) ch.emplace(c, 0);
for (char c : t) ch.emplace(c, 0);
for (char c : w) ch.emplace(c, 0);
if (ch.size() > 10) {
cout << "UNSOLVABLE";
return;
}
int p[] = {0, 1, 2, 3, 4, 5, 6, 7, 8, 9};
do {
string a, b, c;
int i = 0;
for (auto it = ch.begin(); it != ch.end(); ++it, i++)
it->second = p[i];
for (char x : s) a.push_back(ch[x] + '0');
for (char x : t) b.push_back(ch[x] + '0');
for (char x : w) c.push_back(ch[x] + '0');
ll A = stoll(a), B = stoll(b), C = stoll(c);
if (a[0] != '0' && b[0] != '0' && c[0] != '0' && A + B == C) {
cout << a << "\n"
<< b << "\n"
<< c << "\n";
return;
}
} while (next_permutation(p, p + 10));
cout << "UNSOLVABLE";
}
E - Unique Color
题意:
思路:用 DFS 搜索一下即可
// Murabito-B 21/04/12
#include <bits/stdc++.h>
using namespace std;
using ll = long long;
const int N = 100005;
int n, c[N], cnt[N], good[N];
vector<int> to[N];
void dfs(int u, int fa) {
if (cnt[c[u]] == 0) good[u] = 1;
cnt[c[u]]++;
for (int i = 0, v; i < to[u].size(); i++)
if ((v = to[u][i]) != fa) dfs(v, u);
cnt[c[u]]--;
}
void solve() {
cin >> n;
for (int i = 1; i <= n; ++i) cin >> c[i];
for (int i = 1, u, v; i < n; ++i) cin >> u >> v, to[u].push_back(v), to[v].push_back(u);
dfs(1, 0);
for (int i = 1; i <= n; ++i)
if (good[i]) cout << i << "\n";
}
int main() {
ios_base::sync_with_stdio(false), cin.tie(0);
solve();
return 0;
}
F题表示是懵逼的,做不来
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
· 一个奇形怪状的面试题:Bean中的CHM要不要加volatile?
· 分享4款.NET开源、免费、实用的商城系统
· Obsidian + DeepSeek:免费 AI 助力你的知识管理,让你的笔记飞起来!
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
· 全程不用写代码,我用AI程序员写了一个飞机大战
2020-04-12 KMP算法-从头到尾彻底理解KMP
2020-04-12 HihoCoder-Trie树
2020-04-12 理解 Hanoi 汉诺塔非递归算法