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题题解的更多相关文章

  1. M-SOLUTIONS Programming Contest 2021(AtCoder Beginner Contest 232) 题解

    目录 G - Modulo Shortest Path H - King's Tour 因为偷懒就只写G和H的题解了. G - Modulo Shortest Path 首先可以观察到对于一条从点\( ...

  2. AtCoder Beginner Contest 076

    A - Rating Goal Time limit : 2sec / Memory limit : 256MB Score : 100 points Problem Statement Takaha ...

  3. atcoder beginner contest 251(D-E)

    Tasks - Panasonic Programming Contest 2022(AtCoder Beginner Contest 251)\ D - At Most 3 (Contestant ...

  4. AtCoder Beginner Contest 100 2018/06/16

    A - Happy Birthday! Time limit : 2sec / Memory limit : 1000MB Score: 100 points Problem Statement E8 ...

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

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

  6. AtCoder Beginner Contest 184 题解

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

  7. AtCoder Beginner Contest 255(E-F)

    Aising Programming Contest 2022(AtCoder Beginner Contest 255) - AtCoder E - Lucky Numbers 题意: 给两个数组a ...

  8. AtCoder Beginner Contest 052

    没看到Beginner,然后就做啊做,发现A,B太简单了...然后想想做完算了..没想到C卡了一下,然后还是做出来了.D的话瞎想了一下,然后感觉也没问题.假装all kill.2333 AtCoder ...

  9. AtCoder Beginner Contest 053 ABCD题

    A - ABC/ARC Time limit : 2sec / Memory limit : 256MB Score : 100 points Problem Statement Smeke has ...

  10. AtCoder Beginner Contest 136

    AtCoder Beginner Contest 136 题目链接 A - +-x 直接取\(max\)即可. Code #include <bits/stdc++.h> using na ...

随机推荐

  1. 总结(5)--- Numpy和Pandas库常用函数

    二.常用库 1.NumPy NumPy是高性能科学计算和数据分析的基础包.部分功能如下: ndarray, 具有矢量算术运算和复杂广播能力的快速且节省空间的多维数组. 用于对整组数据进行快速运算的标准 ...

  2. Batrix企业能力库之物流交易域能力建设实践

    简介 Batrix企业能力库,是京东物流战略级项目-技术中台架构升级项目的基础底座.致力于建立企业级业务复用能力平台,依托能力复用业务框架Batrix,通过通用能力/扩展能力的定义及复用,灵活支持业务 ...

  3. MVC控制器传DataTable

    MVC中,控制器return Json(DataTable)会出现错误: 序列化类型为"System.Reflection.RuntimeModule"的对象时检测到循环引用. 解 ...

  4. C# 常量 结构体 委托

    常量 const double PI = 3.1415926; 常量名命名一般使用大写字母 枚举类型 开发一个游戏,游戏角色有法师(Mage).射手(Archer).刺客(Assassin).坦克(T ...

  5. React Hooks 钩子特性

    人在身处逆境时,适应环境的能力实在惊人.人可以忍受不幸,也可以战胜不幸,因为人有着惊人的潜力,只要立志发挥它,就一定能渡过难关. Hooks 是 React 16.8 的新增特性.它可以让你在不编写 ...

  6. 解决OpenCV3+VS2015(VS2017)运行时出现debug error abort()has been called的问题

    问题描述: 在windows平台上安装opencv后,测试一张图片时,出现了debug error abort()has been called的问题 环境: vs2015 windows 10 op ...

  7. SpringBoot设置日志级别

    输出到控制台 logging: # 日志记录到文件中 file: # 指定文件名 name: server.log logback: rollingpolicy: # 指定文件大小 max-file- ...

  8. 如何有效应对员工违规使用U盘的情况?

    在面对员工违规使用U盘的挑战时,华企盾DSC数据防泄密系统提供了一套综合而高效的解决方案. 通过系统的U盘加密功能,我们能够防止未经授权的U盘访问,确保敏感数据不会被非法传输.这一层保护不仅是基础性的 ...

  9. ElasticSearch之cat shards API

    命令样例如下: curl -X GET "https://localhost:9200/_cat/shards?v=true&pretty" --cacert $ES_HO ...

  10. 一键打包,随时运行,Python3项目虚拟环境一键整合包的制作(Venv)

    之前我们介绍了如何使用嵌入式 Python3 环境给项目制作一键整合包,在使用嵌入式 Python 环境时,通常是作为另一个应用程序的一部分,而Python3虚拟环境是为了在开发过程中隔离项目所需的 ...