AtCoder Beginner Contest 165
比赛链接:https://atcoder.jp/contests/abc165/tasks
A - We Love Golf
题意
区间 $[a, b]$ 中是否存在 $k$ 的倍数。
代码
#include <bits/stdc++.h>
using namespace std;
int main() {
int k, a, b; cin >> k >> a >> b;
for (int i = a; i <= b; i++) {
if (i % k == 0) {
cout << "OK";
return 0;
}
}
cout << "NG";
}
B - 1%
题意
一开始在银行存有 $100$ 元,年利率为 $\lfloor \frac{n}{100} \rfloor$,问多少年后存款不少于 $x$ 元。
代码
#include <bits/stdc++.h>
using namespace std;
int main() {
long long x; cin >> x;
long long sum = 100;
for (int i = 1; i < INT_MAX; i++) {
sum += sum / 100;
if (sum >= x) {
cout << i << "\n";
return 0;
}
}
}
C - Many Requirements
题意
构造一个长为 $n$ 的数组 $A$,其中 $1 ≤ A_1 ≤ A_2 ≤ ... ≤ A_n ≤ m$。
另有数组 $a,b,c,d$,如果 $A_{b_i} - A_{a_i} = c_i$,则该数组的价值加上 $d_i$ ,求能构造出的数组的最大价值。
题解
枚举所有情况即可。
代码
#include <bits/stdc++.h>
using namespace std; int n, m, q;
int a[50], b[50], c[50], d[50];
int A[10], ans; void dfs(int dep, int pre) {
if (dep == n) {
int sum = 0;
for (int i = 0; i < q; i++)
if (A[b[i]] - A[a[i]] == c[i]) sum += d[i];
ans = max(ans, sum);
return;
}
for (int i = pre; i <= m; i++) {
A[dep] = i;
dfs(dep + 1, i);
}
} int main() {
cin >> n >> m >> q;
for (int i = 0; i < q; i++) {
cin >> a[i] >> b[i] >> c[i] >> d[i];
--a[i], --b[i];
}
dfs(0, 1);
cout << ans << "\n";
}
D - Floor Function
题意
求 $max( \lfloor \frac{Ax}{B} \rfloor - A \lfloor \frac{x}{B} \rfloor )$ 。
题解
设 $x = cB + d\ (0≤c,\ 0≤d<B)$
$\ \ \ \ \lfloor \frac{Ax}{B} \rfloor - A \lfloor \frac{x}{B} \rfloor$
$=\lfloor \frac{A(cB+d)}{B} \rfloor - A \lfloor \frac{cB+d}{B} \rfloor$
$=Ac + \lfloor \frac{Ad}{B} \rfloor - Ac - A \lfloor \frac{d}{B} \rfloor$
$=\lfloor \frac{Ad}{B} \rfloor - A \lfloor \frac{d}{B} \rfloor$
$=\lfloor \frac{Ad}{B} \rfloor$
即求 $max(\lfloor \frac{Ad}{B} \rfloor)$,取 $d$ 的最大值即可。
代码
#include <bits/stdc++.h>
using namespace std;
int main() {
long long a, b, n; cin >> a >> b >> n;
cout << a * min(b - 1, n) / b << "\n";
}
E - Rotation Matching
题意
有 $n$ 个选手,$m$ 个比赛场地,为每 $m$ 个比赛场地指定一对选手的编号(一个编号只能出现在一个比赛场地),来保证在之后的 $n$ 轮比赛中,所有选手不会与同一选手比赛两次,每轮比赛后所有选手编号加 $1$,编号 $n+1$ 的变为 $1$。
题解
一个选手最多的情况是要与 $m$ 个人一人比一次,所以 $m$ 对编号应取 $m$ 个不同的间隔。
即在 $[1, n]$ 中取 $m$ 对数,每对数间隔不同的长度。
代码
待填
F - LIS on Tree
题意
一棵有 $n$ 个结点的树,每个结点有一个值,输出每个从根节点 $1$ 到其他点最短路的值序列中 $LIS$ 的长度。
题解
维护一个最长单调序列即可。
代码一
#include <bits/stdc++.h>
using namespace std; const int M = 2e5 + 100;
vector<int> e[M];
int a[M], ans[M];
int b[M], len; void dfs(int u, int pre) {
int id = lower_bound(b, b + len, a[u]) - b;
int del = -1;
if (id == len) ++len;
else del = b[id];
b[id] = a[u];
ans[u] = len;
for (auto v : e[u]) {
if (v != pre) {
dfs(v, u);
}
}
if (del == -1) --len;
else b[id] = del;
} int main() {
int n; cin >> n;
for (int i = 0; i < n; i++) cin >> a[i];
for (int i = 0; i < n - 1; i++) {
int u, v; cin >> u >> v;
--u, --v;
e[u].push_back(v);
e[v].push_back(u);
}
dfs(0, -1);
for (int i = 0; i < n; i++) cout << ans[i] << "\n";
}
代码二
再贴一下用 $set$ 的做法,需要注意一些语句的前后顺序。
#include <bits/stdc++.h>
using namespace std; const int M = 2e5 + 100;
vector<int> e[M];
int a[M], ans[M];
set<int> st; void dfs(int u, int pre) {
auto it = st.lower_bound(a[u]);
int del = -1;
if (it != st.end()) {
del = *it;
st.erase(it);
}
st.insert(a[u]);
ans[u] = st.size();
for (auto v : e[u]) {
if (v != pre) {
dfs(v, u);
}
}
st.erase(a[u]);
if (del != -1) st.insert(del);
} int main() {
int n; cin >> n;
for (int i = 0; i < n; i++) cin >> a[i];
for (int i = 0; i < n - 1; i++) {
int u, v; cin >> u >> v;
--u, --v;
e[u].push_back(v);
e[v].push_back(u);
}
dfs(0, -1);
for (int i = 0; i < n; i++) cout << ans[i] << "\n";
}
AtCoder Beginner Contest 165的更多相关文章
- 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 我要崩溃,当时还以为是需要什么离散化的,原来是暴力,特么五层循环....我自己写怎么都 ...
随机推荐
- 新蜂商城的mybatis plus版本,添加了秒杀专区、优惠卷领取以及后台搜索功能
本项目是在newbee-mall项目的基础上改造而来,将orm层由mybatis替换为mybatis-plus,添加了秒杀功能.优惠劵功能以及后台搜索功能,喜欢的话麻烦给我个star 后台管理模块添加 ...
- 【Linux】linux中用vim来比较文件内容不同
1. 使用vim的比较模式打开两个文件: vim -d file1 file2 或 vimdiff file1 file2 2. 如果已经打开了文件file1,再打开另一个文件file2进行比较: : ...
- 【RAC】安装rac的时候。报错checking for oracle home incompatibilities failed
背景:由于oracle安装的时候中途出现了问题,解决过后,发现报错了 图形化安装的时候,有这个问题出现 解决办法: 删除安装过的所有缓存,和文件即可 1.删除ORACLE_BASE下的所有文件 2.删 ...
- 强制删除 Terminating 状态的pod
[root@k8s-master coredns]# kubectl get podNAME READY STATUS RESTARTS ...
- 实操|如何将 Containerd 用作 Kubernetes runtime
日前专为开发者提供技术分享的又拍云 OpenTalk 公开课邀请了网易有道资深运维开发工程师张晋涛,直播分享<Containerd 上手实践 >,详细介绍 Containerd 的发展历程 ...
- 【1w字+干货】第一篇,基础:让你的 Redis 不再只是安装吃灰到卸载(Linux环境)
Redis 基础以及进阶的两篇已经全部更新好了,为了字数限制以及阅读方便,分成两篇发布. 本篇主要内容为:NoSQL 引入 Redis ,以及在 Linux7 环境下的安装,配置,以及总结了非常详细的 ...
- numpy模块(详解)
重点 索引和切片 级联 聚合操作 统计操作 矩阵 什么是数据分析 是把隐藏在一些看似杂乱无章的数据背后的信息提炼出来,总结出所研究对象的内在规律 数据分析是用适当的方法对收集来的大量数据进行分析,帮助 ...
- java虚拟机入门(二)-探索内存世界
上节简单介绍了一下jvm的内存布局以及简单概念,那么对于虚拟机来说,它是怎么一步步的让我们能执行方法的呢: 1.首先,jvm启动时,跟个小领导一样会根据配置参数(没有配置的话jvm会有默认值)向大领导 ...
- SuperUpdate.sh 一键更换Linux软件源脚本
一.前言 有时候会遇到 Linux 的源更新速度非常的缓慢,特别是在国内使用默认的源,因为国内的网络环境,经常会出现无法更新,更新缓慢的情况.在这种情况下,更换一个更适合或者说更近,更快的软件源,会为 ...
- Java并发组件二之CyclicBarriar
使用场景: 多个线程相互等待,直到都满足条件之后,才能执行后续的操作.CyclicBarrier描述的是各个线程之间相互等待的关系. 使用步骤: 正常实例化:CyclicBarrier sCyclic ...