补题链接:Here

A - Div

题意:N 个不一样的糖,请问有多少种分法给 A,B两人

水题,写几组情况就能知道输出 \(N - 1\) 即可

B - Palindrome with leading zeros

题意:给定一个字符串,问是否可以在字符串前加若干个 0 使字符串回文

先判断一下字符串回文否?本身就回文就无需处理,不然字符串后面有几个 0 就加上多少,然后再判断

C - Compass Walking

题意:在一个二维坐标轴上,给定一个长度 R ,请问是否有最小步数(每步只能走 R,但坐标可以非整数)到达 \((X,Y)\)

思路:

假设 \(d\) 为 起点\((0,0)\) 至 \((X,Y)\) 的欧几里得距离,则容易想到以下三种情况

  • 答案为 \(1\) ,如果 \(d = R\)
  • 答案为 \(2\) ,如果 \(d \ne R\) 并且 \(d < R\)
  • \(\lceil \frac{d}{R} \rceil\) ,其他情况

其实这里 第一种情况和第三种情况可合并写: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

题意:给定 \(3\) 个字符串 \(N_1,N_2,N_3\) 试问是否有数字能代替某种字母使得 \(N_1 + N_2 = N_3\)

思路:

首先,如果出现 \(10\) 种以上的字母,那么肯定是无法解决的,直接输出 UNSOLVABLE 即可

对于剩下的情况来说,可以尝试把数字分配给字母,然后 check 一下 \(N_1 + N_2 = N_3\) 。

\(10 ! = 3628800\) 是可执行范围内

注意别给首位分配 \(0\) 即可

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题表示是懵逼的,做不来

AtCoder Beginner Contest 198 个人题解(AB水题,C思维,D思维+全排列,E题DFS搜索,F懵逼)的更多相关文章

  1. KYOCERA Programming Contest 2021(AtCoder Beginner Contest 200) 题解

    KYOCERA Programming Contest 2021(AtCoder Beginner Contest 200) 题解 哦淦我已经菜到被ABC吊打了. A - Century 首先把当前年 ...

  2. AtCoder Beginner Contest 022 A.Best Body 水题

    Best Body Time Limit: 20 Sec  Memory Limit: 256 MB 题目连接 http://abc022.contest.atcoder.jp/tasks/abc02 ...

  3. AtCoder Beginner Contest 069【A,水,B,水,C,数学,D,暴力】

    A - K-City Time limit : 2sec / Memory limit : 256MB Score : 100 points Problem Statement In K-city, ...

  4. 2018.09.08 AtCoder Beginner Contest 109简要题解

    比赛传送门 水题大赛? 全是水题啊!!! T1 ABC333 就是判断是不是两个数都是奇数就行了. 代码: #include<bits/stdc++.h> using namespace ...

  5. AtCoder Beginner Contest 089完整题解

    A - Grouping 2 Time limit : 2sec / Memory limit : 256MB Score : 100 points Problem Statement There a ...

  6. Atcoder Beginner Contest 138 简要题解

    D - Ki 题意:给一棵有根树,节点1为根,有$Q$次操作,每次操作将一个节点及其子树的所有节点的权值加上一个值,问最后每个节点的权值. 思路:dfs序再差分一下就行了. #include < ...

  7. AtCoder Beginner Contest 184 题解

    AtCoder Beginner Contest 184 题解 目录 AtCoder Beginner Contest 184 题解 A - Determinant B - Quizzes C - S ...

  8. AtCoder Beginner Contest 153 题解

    目录 AtCoder Beginner Contest 153 题解 A - Serval vs Monster 题意 做法 程序 B - Common Raccoon vs Monster 题意 做 ...

  9. AtCoder Beginner Contest 148 题解

    目录 AtCoder Beginner Contest 148 题解 前言 A - Round One 题意 做法 程序 B - Strings with the Same Length 题意 做法 ...

  10. AtCoder Beginner Contest 154 题解

    人生第一场 AtCoder,纪念一下 话说年后的 AtCoder 比赛怎么这么少啊(大雾 AtCoder Beginner Contest 154 题解 A - Remaining Balls We ...

随机推荐

  1. offline RL | BCQ:学习 offline dataset 的 π(a|s),直接使用 (s, π(s)) 作为 Q learning 训练数据

    题目: Off-Policy Deep Reinforcement Learning without Exploration,ICLR 2019 pdf 版本:https://arxiv.org/pd ...

  2. Codeforces Round 903 (Div. 3)

    Codeforces Round 903 (Div. 3) A. Don't Try to Count 大概题意给你两个字符串a,b.a串可进行的操作为将整个a串复制到之前的a串后面(直接用a+a即可 ...

  3. 如何用MySQL快速导入sql数据?

    在 MySQL 中,可以使用多种方法来快速导入 SQL 数据.以下是一些常用的方法和技巧,以帮助你在 MySQL 中快速导入大量的 SQL 数据. 1. 使用 mysql 命令行工具 - 将 SQL ...

  4. 【scikit-learn基础】--『数据加载』之玩具数据集

    机器学习的第一步是准备数据,好的数据能帮助我们加深对机器学习算法的理解. 不管是在学习还是实际工作中,准备数据永远是一个枯燥乏味的步骤.scikit-learn库显然看到了这个痛点,才在它的数据加载子 ...

  5. C++ 邮件槽ShellCode跨进程传输

    在计算机安全领域,进程间通信(IPC)一直是一个备受关注的话题.在本文中,我们将探讨如何使用Windows邮件槽(Mailslot)实现ShellCode的跨进程传输.邮件槽提供了一种简单而有效的单向 ...

  6. viewPager2页面的切换

    使用流程:   1.定义ViewPager   2.为ViewPager创建Adapter ViewPagerAdapter package com.example.viewpagerandfragm ...

  7. 神经网络优化篇:如何理解 dropout(Understanding Dropout)

    理解 dropout Dropout可以随机删除网络中的神经单元,为什么可以通过正则化发挥如此大的作用呢? 直观上理解:不要依赖于任何一个特征,因为该单元的输入可能随时被清除,因此该单元通过这种方式传 ...

  8. VisionPro学习笔记(6)——如何使用QuickBuild

    如果需要了解其他图像处理的文章,请移步小编的GitHub地址 传送门:请点击我 如果点击有误:https://github.com/LeBron-Jian/ComputerVisionPractice ...

  9. BUUCTF 加固题 Ezsql WriteUp

    文章目录 想直接要加固代码的点这里 题目 一.查看 二.进入目标机器加固 修改前的文件: 添加如下代码: 修改后的文件 三.Check 想直接要加固代码的点这里 题目 靶机地址解释: 第一行:目标机器 ...

  10. Numpy计算近邻表时间对比

    技术背景 所谓的近邻表求解,就是给定N个原子的体系,找出满足cutoff要求的每一对原子.在前面的几篇博客中,我们分别介绍过CUDA近邻表计算与JAX-MD关于格点法求解近邻表的实现.虽然我们从理论上 ...