AtCoder Beginner Contest 204 (AB水题,C题DFS,D题位运算DP,E题BFS好题)
补题链接:Here
A - Rock-paper-scissors
石头剪刀布,两方是一样的则输出该值,否则输出该值
int s[4] = {0, 1, 2};
void solve() {
int x, y;
cin >> x >> y;
if (x == y) cout << x;
else {
for (int i = 0; i < 3; i++)
if (s[i] != x && s[i] != y)
cout << s[i];
}
}
B - Nuts
坚果数超过 \(10\) 个便累加(x-10)
void solve() {
int n;
cin >> n;
int cnt = 0;
for (int i = 0, x; i < n; ++i) {
cin >> x;
if (x > 10)cnt += (x - 10);
}
cout << cnt;
}
C - Tour
\(n\) 个城市,\(m\) 条单向道路,请问在以每个城市为起点能有多少个终点(本身也算
\(n\le2000\) ,DFS 在图上搜索即可
const int N = 2e3 + 10;
vector<int>e[N];
bool vis[N];
void dfs(int u) {
if (vis[u])return ;
vis[u] = true;
for (int v : e[u])dfs(v);
}
void solve() {
int n, m; cin >> n >> m;
while (m--) {
int a, b; cin >> a >> b;
e[a].push_back(b);
}
int ans = 0;
for (int i = 1; i <= n; ++i) {
memset(vis, false, sizeof(vis));
dfs(i);
for (int j = 1; j <= n; ++j)if (vis[j])ans++;
}
cout << ans;
}
D - Cooking
两个微波炉,\(n\) 道菜,每个菜需要 \(a_i\) 分钟加热,请问最少需要多少时间才能把所有菜都加热完毕
烤箱的使用顺序无关紧要;只有为每道菜指定一个烤箱才是必要的。
考虑到根据要分配的两个烤箱中的哪一个将菜分为两组,该问题等价于“将N个菜分为两组,使烹调菜所需的最大次数之和最小化。”设为 \(t_1+…+t_n\)。我们可以假设第一个烤箱的占用时间不少于第二个烤箱的占用时间(如果不是,我们可以交换这两个烤箱)。然后,第一烤箱的使用持续时间至少为 \(S/2\) 。由于我们想在这个约束条件下尽可能减少使用第一台烤箱的时间,所以问题归结为“\(t_1…t_n\)的子集的最小和大于或等于 \(S/2\) 是多少?”如果我们能为每个x回答“ \(T_1,…,T_N\)的子集是否存在,这只不过是一个子集和问题,所以它可以在 \(\mathcal{O}(N\sum_iT_i)\) 的总和中找到∑ 具有以下布尔值的DP
bitset<100004>f;
void solve() {
int n; cin >> n;
int cnt = 0;
f[0] = 1;
for (int i = 0, x; i < n; ++i) {
cin >> x;
f |= f << x; cnt += x;
}
int ans = 1e9;
for (int i = 0; i < 1e5; ++i)if (f[i])ans = min(ans, max(i, cnt - i));
cout << ans;
}
E - Rush Hour 2
AtCoder王国有 \(n\) 个城市和 \(m\) 条双向道路
假设在 \(t\) 时刻经过了第 \(i\) 条道路,则通过的时间为 \(C_i + ⌊\frac{D_i}{t+1}⌋\)
现在请问最短的时间是多少,Takahashi 可以从城市 \(1\) 到达城市 \(n\) ,如果到达不了则输出 \(-1\)
利用优先队列跑 BFS,同时用 tuple 元组存储数据 (记得开启 C++17 来保证 tuple 可通过编译)
#define inf 9223372036854775807LL
#define N 100005
using ll = long long;
using Edge = tuple<int, int, int>;
using pli = pair<ll, int>;
vector<Edge> e[N];
ll dist[N];
void solve() {
int n, m;
cin >> n >> m;
while (m--) {
int a, b, c, d;
cin >> a >> b >> c >> d;
if (--a == --b)continue;
e[a].emplace_back(b, c, d);
e[b].emplace_back(a, c, d);
}
dist[0] = 0LL;
for (int i = 1; i < n; i++) dist[i] = inf;
priority_queue<pli, vector<pli>, greater<pli>>q;
q.emplace(0, 0);
while (!q.empty()) {
auto [t, u] = q.top();
q.pop();
if (dist[u] != t)continue;
for (auto [v, c, d] : e[u]) {
ll t2 = sqrt((long double) d) - 0.5;
if (t2 < t) t2 = t;
t2 += ll(c) + ll(d) / (t2 + 1ll);
if (t2 < dist[v])
q.emplace(dist[v] = t2, v);
}
}
cout << (dist[n - 1] == inf ? -1 : dist[n - 1]) << endl;
}
AtCoder Beginner Contest 204 (AB水题,C题DFS,D题位运算DP,E题BFS好题)的更多相关文章
- AtCoder Beginner Contest 204
身败名裂了,\(AK\)场转掉分场. 都是水题不说了. 这篇文鸽了.
- AtCoder Beginner Contest 087 D People on a Line(DFS)
题意 给出n个点,m组关系L,R,D,L在R的左边距离D,判断是否存在n个人的位置满足m组关系 分析 Consider the following directed graph G: There ar ...
- AtCoder Beginner Contest 068 ABCD题
A - ABCxxx Time limit : 2sec / Memory limit : 256MB Score : 100 points Problem Statement This contes ...
- AtCoder Beginner Contest 053 ABCD题
A - ABC/ARC Time limit : 2sec / Memory limit : 256MB Score : 100 points Problem Statement Smeke has ...
- AtCoder Beginner Contest 223
AtCoder Beginner Contest 223 A是纯纯的水题,就不说了 B - String Shifting 思路分析 我真的sb,一开始想了好久是不是和全排列有关,然后读了好几遍题目也 ...
- AtCoder Beginner Contest 184 题解
AtCoder Beginner Contest 184 题解 目录 AtCoder Beginner Contest 184 题解 A - Determinant B - Quizzes C - S ...
- AtCoder Beginner Contest 052
没看到Beginner,然后就做啊做,发现A,B太简单了...然后想想做完算了..没想到C卡了一下,然后还是做出来了.D的话瞎想了一下,然后感觉也没问题.假装all kill.2333 AtCoder ...
- AtCoder Beginner Contest 137 F
AtCoder Beginner Contest 137 F 数论鬼题(虽然不算特别数论) 希望你在浏览这篇题解前已经知道了费马小定理 利用用费马小定理构造函数\(g(x)=(x-i)^{P-1}\) ...
- AtCoder Beginner Contest 075 C bridge【图论求桥】
AtCoder Beginner Contest 075 C bridge 桥就是指图中这样的边,删除它以后整个图不连通.本题就是求桥个数的裸题. dfn[u]指在dfs中搜索到u节点的次序值,low ...
- AtCoder Beginner Contest 153 题解
目录 AtCoder Beginner Contest 153 题解 A - Serval vs Monster 题意 做法 程序 B - Common Raccoon vs Monster 题意 做 ...
随机推荐
- Jenkins从Ubuntu迁移至AlmaLinux问题及相关解决记录
相关背景 之前在Ubuntu平台上搭建了Jenkins(在Ubuntu机器上使用war包安装Jenkins),现在由于一些需求,需要将系统迁移到AlmaLinux平台.由于AlmaLinux属于Cen ...
- AtCoder_abc326
T1 2UP3DOWN 简单的if判断,做题一分钟,翻译十分钟... 代码: #include<bits/stdc++.h> using namespace std; int main() ...
- 生物电势测量ECG
参考来源:ADI官网技术文章.知乎(hxl695822705.KingPo-张超.津发科技.木森.深圳加1健康科技) ECG的产生 ECG(Electrocardiogram)心电测量,是指人体内窦房 ...
- Java自定义ClassLoader实现插件类隔离加载
为什么需要类隔离加载 项目开发过程中,需要依赖不同版本的中间件依赖包,以适配不同的中间件服务端 如果这些中间件依赖包版本之间不能向下兼容,高版本依赖无法连接低版本的服务端,相反低版本依赖也无法连接高版 ...
- javascript+php 实现blob加密视频(html video)
1.mp4地址加密为blob链接在html5的video标签展示 PHP: 1 $file_path = "...mp4"; //视频文件地址 2 ob_end_clean(); ...
- [ARC169E] Avoid Boring Matches
题解链接 非常厉害的一道题. 考虑无解是什么情况? R 的个数超过 \(2^{n-1}\) 先考虑如何判定.从前往后考虑,如果遇到一个 B,那么如果后面有 R,就选最靠前的 R,否则选最靠后的一个 B ...
- drf实战和源码剖析----学习笔记1
学自:bilibili武沛齐老师. 武老师讲课:清晰,连贯,实用,透彻,真乃名师! # 1. 什么是前后端分离 - 不分离,主要用于后台系统(CRUD)和用户量上的情况,开发起来代价小- 分离,面向用 ...
- WPF 入门基础
关于 WPF 和 XAML 什么是 WPF WPF(Windows Presentation Foundation)是由微软开发的桌面应用程序框架,用于创建现代化.高度交互和具有视觉吸引力的用户界面. ...
- 基于python人脸识别考勤系统(语音播报)
介绍: 本项目是大二寒假在家没事写的,一直没有时间讲本项目分享出来,现在有时间了哈.那就让我简单的将项目介绍一下吧.好了废话不多说了,直接上图 初始化界面: 可以看到所有的功能都展现在了左边的功能栏中 ...
- 使用axios发送请求的几种方式
1.是什么? axios 它的底层是用了 XMLHttpRequest(xhr)方式发送请求和接收响应,xhr 相对于之前讲过的 fetch api 来说,功能更强大,但由于是比较老的 api,不支持 ...