AtCoder Beginner Contest 195 Editorial
AtCoder Beginner Contest 195 Editorial
Problem A - Health M Death(opens new window)
只要检查 \(H\equiv 0\) 即可.
- Time complexity is \(\mathcal{O}(1)\).
- Space complexity is \(\mathcal{O}(1)\).
Code(C++)
int main() {
ios_base::sync_with_stdio(false), cin.tie(0);
int M, H;
cin >> M >> H;
cout << (H % M == 0 ? "Yes\n" : "No\n");
return 0;
}
Problem B - Many Oranges(opens new window)
注意 \(W\) 是以千克为单位,所以需要以 \(1000W\) 代替 \(W\)
首先先来分析上限:
尽可能使用 A 来达到上限,但问题是可能会有剩余的克数
,我们需要将其分配给 \(B\) 即可
- Time complexity is \(\mathcal{O}(1)\)).
- Space complexity is \(\mathcal{O}(1)\).
Code (C++)
int main() {
ios_base::sync_with_stdio(false), cin.tie(0);
int A, B, W;
cin >> A >> B >> W;
W *= 1000;
int minn = W / B;
int maxn = W / A;
if (minn + (W % B != 0) <= maxn) {
cout << minn + (W % B != 0) << ' ' << maxn << "\n";
} else {
cout << "UNSATISFIABLE\n";
}
return 0;
}
Problem C - Comma(opens new window)
- [1,9]: 9 numbers, each has 0 commas.
- [10,99]: 90 numbers, each has 0 commas.
- [100,999]: 900 numbers, each has 0 commas.
- [1000,9999]: 9000 numbers, each has 1 comma.
- \(\cdots\)
基于以上模式可以很简单从 \(1000\) 开始,然后每 \(10\) 倍的递增直到超过 \(N\).
- Time complexity is \(\mathcal{O}(\log_{10}N)\).
- Space complexity is \(\mathcal{O}(1)\).
Code (Rust)
use proconio::input;
fn main() {
input! {
n: usize,
}
let mut base: usize = 1_000;
let mut ans: usize = 0;
let mut cnt = 3;
while base <= n {
let num = (n - base + 1).min(base * 9);
ans += num * (cnt / 3);
cnt += 1;
base *= 10;
}
println!("{}", ans);
}
Code (C++)
using ll = long long;
int main() {
ios_base::sync_with_stdio(false), cin.tie(0);
ll n, ans = 0;
cin >> n;
if (n > 999) ans += n - 999;
if (n > 999999) ans += n - 999999;
if (n > 999999999) ans += n - 999999999;
if (n > 999999999999) ans += n - 999999999999;
if (n > 999999999999999) ans += n - 999999999999999;
cout << ans << "\n";
return 0;
}
Problem D - Shipping Center(opens new window)
第一眼看过去是线段树问题,但数据范围较小可以暴力找。
对于每个查询,我们收集所有可用的框,并根据其容量以升序对其进行排序。 对于每个盒子,我们从没有使用过的,盒子可以容纳的所有物品中,贪婪地选择最有价值的行李。
- Time complexity is \(\mathcal{O}(QM(N+\log M))\).
- Space complexity is \(\mathcal{O}(1)\).
Code (C++)
using ll = long long;
typedef pair pii;
int main() {
ios_base::sync_with_stdio(false), cin.tie(0);
int n, m, q;
cin >> n >> m >> q;
vector wv(n);
vector x(m);
for (int i = 0; i < n; ++i) cin >> wv[i].second >> wv[i].first;
for (int i = 0; i < m; ++i) cin >> x[i];
sort(wv.begin(), wv.end(), greater());
while (q--) {
multiset s;
// 避免使用 Set 增加不必要的排序,因为上面已经排好序了
ll ans = 0;
int l, r;
cin >> l >> r;
for (int i = 0; i < l - 1; ++i) s.insert(x[i]);
for (int i = r; i < m; ++i) s.insert(x[i]);
multiset::iterator it;
for (int i = 0; i < n; ++i) {
if ((it = s.lower_bound(wv[i].second)) != s.end())
s.erase(it), ans += wv[i].first;
}
cout << ans << "\n";
// cout << "\n";
}
return 0;
}
Problem E - Lucky 7 Battle(opens new window)
不难发现,在这个游戏中,只有\(7\)的模数很重要。 因此,我们将精确地具有\(7\)个状态,表示当前的模数。
从后开始,因为我们只知道游戏结束时的赢/输状态:$0 = \text{Takahashi获胜} ,\text {others} = \text{Aoki获胜} $
对于每一步,我们都会枚举所有 \(7\)个模,并计算其后继者:\(a =(last * 10)%7,b =(last * 10 + s [i])%7\)。
如果高桥移动,则他需要 \(a\)或\(b\)才能成为获胜状态(对于高桥来说),以便last将成为获胜状态。
如果Aoki移动,他需要 \(a\)和b\(b\)成为失败状态(对于Takahashi),以便last将成为失败状态,否则(a和b均为获胜状态),last将成为获胜状态。
并且我们只需要首先检查 \(0\) 是否为获胜状态。
- Time complexity is \(\mathcal{O}(CN), where\ C=7\).
- Space complexity is \(\mathcal{O}(C)\).
using ll = long long;
int p7[8] = {1, 3, 2, 6, 4, 5};
int main() {
ios_base::sync_with_stdio(false), cin.tie(0);
int l;
cin >> l;
string s, t;
cin >> s >> t;
int mask = 1;
for (int i = l - 1; i >= 0; i--) {
int tg = (p7[(l - 1 - i) % 6] * (s[i] - '0')) % 7;
int nm = (mask << tg);
nm |= (nm >> 7);
nm &= (1 << 7) - 1;
if (t[i] == 'T') mask |= nm;
else
mask &= nm;
// cout << mask << '\n';
}
cout << (mask & 1 ? "Takahashi\n" : "Aoki\n");
return 0;
}
AtCoder Beginner Contest 195 Editorial的更多相关文章
- AtCoder Beginner Contest 100 2018/06/16
A - Happy Birthday! Time limit : 2sec / Memory limit : 1000MB Score: 100 points Problem Statement E8 ...
- 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 ...
- AtCoder Beginner Contest 137 F
AtCoder Beginner Contest 137 F 数论鬼题(虽然不算特别数论) 希望你在浏览这篇题解前已经知道了费马小定理 利用用费马小定理构造函数\(g(x)=(x-i)^{P-1}\) ...
- AtCoder Beginner Contest 076
A - Rating Goal Time limit : 2sec / Memory limit : 256MB Score : 100 points Problem Statement Takaha ...
- AtCoder Beginner Contest 079 D - Wall【Warshall Floyd algorithm】
AtCoder Beginner Contest 079 D - Wall Warshall Floyd 最短路....先枚举 k #include<iostream> #include& ...
- AtCoder Beginner Contest 064 D - Insertion
AtCoder Beginner Contest 064 D - Insertion Problem Statement You are given a string S of length N co ...
- AtCoder Beginner Contest 075 D - Axis-Parallel Rectangle【暴力】
AtCoder Beginner Contest 075 D - Axis-Parallel Rectangle 我要崩溃,当时还以为是需要什么离散化的,原来是暴力,特么五层循环....我自己写怎么都 ...
- AtCoder Beginner Contest 075 C bridge【图论求桥】
AtCoder Beginner Contest 075 C bridge 桥就是指图中这样的边,删除它以后整个图不连通.本题就是求桥个数的裸题. dfn[u]指在dfs中搜索到u节点的次序值,low ...
随机推荐
- Centos8离线安装golang
一.下载golang 1.下载安装包 2.下载后解压. tar -zxvf go1.17.linux-amd64.tar.gz 二.配置环境变量 vim /etc/profile 1.在环境变量最后添 ...
- Go笔记(3)-3种go语言的键盘输入详解
go语言的键盘输入详解 go语言中有三种输入函数,分别是: fmt.Scanf() 可以按照指定的格式进行输入 fmt.Scanln() 通过指针将值赋值给变量 fmt.Scan() (1)fmt.S ...
- 【MySql】数据库_MySql基础
yum install mysql mysql -u root -p 创建数据库 create database 数据库名; 查看所有数据仓库 show databases; 删除数据库 drop d ...
- Provider MVVM架构
MVVM架构分为M(Model).V(View).VM(ViewModel)三个部分,他们分别处理自己的分工,在View和Model之间使用ViewModel作为中介者,使View和Model不受业务 ...
- SSH默认端口从22修改为其他端口
1.在终端中使用root权限登录到您的Linux服务器. 2.打开终端,并使用适合您的文本编辑器(如vi.nano等)打开SSH配置文件.例如,通过运行以下命令之一: vi /etc/ssh/sshd ...
- 拖拽功能实现vue
1.按钮 <el-button @mousedown="down" @touchstart="down" @mousemove="move&qu ...
- 华为云弹性云服务器ECS搭建FTP服务实践
摘要:在使用华为弹性云服务器ECS搭建FTP服务的时候,经常会遇到搭建完成后无法访问的问题.本篇通过演示windows IIS搭建FTP方法,讲解ftp主动模式.被动模式原理来说明无法访问的原因及解决 ...
- 面试官问我:CSS有哪些属性可以继承?
摘要:本文带大家学习一下关于CSS属性的继承. 本文分享自华为云社区<关于CSS有哪些属性可以继承?>,作者:黛琳ghz. 前言 今天遇到一个很有意思的题目,通过题目可以顺便学习一下关于C ...
- MRS +Apache Zeppelin,让数据分析更便捷
摘要:选择轻量化.免运维.低成本的大数据云服务是业界趋势,如果搭建Zeppelin再同步自建一套Hadoop生态成本太高!因此我们通过结合华为云MRS服务构建数据中台. 本文分享自华为云社区<M ...
- 华为海外女科学家为您揭秘:GaussDB(for MySQL)云栈垂直集成的力量有多大?
摘要:让数据库性能UP!UP!UP!华为云GaussDB(for MySQL)是这样做的 本文分享自华为云社区<华为海外女科学家为您揭秘:GaussDB(for MySQL)云栈垂直集成的力量有 ...