AtCoder Beginner Contest 210 (A~E)
比赛链接:Here
A - Cabbages
略
B - Bouzu Mekuri
略
C - Colorful Candies
用map维护连续一段区间的不同元素即可。
int main() {
cin.tie(nullptr)->sync_with_stdio(false);
int n, k; cin >> n >> k;
vector<int>a(n + 1);
map<int, int>mp;
for (int i = 1; i <= n; ++i)cin >> a[i];
for (int i = 1; i <= k; ++i)mp[a[i]]++;
int ans = mp.size();
for (int i = k + 1; i <= n; ++i) {
mp[a[i]]++;
mp[a[i - k]]--;
if (mp[a[i - k]] == 0) mp.erase(a[i - k]);
ans = max(ans, (int)mp.size());
}
cout << ans << "\n";
}
D - National Railway
给一个矩阵,矩阵每一个位置都有值,要求选取两个位置使得: \(val=\) 两个位置的值之和 \(+\) 两个位置的曼哈顿距离 \(\times\) 系数 \(c\) 最小。
思路:显然不能枚举两个位置,考虑DP,
设 \(f(i, j)\) 表示在从 \((1, 1)\) 到 \((i, j)\) 内的元素到 \((i, j)\)的距离加上值的最小值。这个就很好转移了。需要注意的是选取的两个点不一定是左上,右下的关系,所以需要沿着右上左下再做一次。
const int N = 1e3 + 10;
ll a[N][N];
int main() {
cin.tie(nullptr)->sync_with_stdio(false);
ll H, W, C;
cin >> H >> W >> C;
vector<vector<ll>>dp(H, vector<ll>(W)), a(H, vector<ll>(W));
for (int i = 0; i < H; ++i)for (int j = 0; j < W; ++j)cin >> a[i][j];
ll _ = 2, Mi = 1ll << 60;
while (_--) {
for (int i = 0; i < H; ++i)
for (int j = 0; j < W; ++j) {
ll up = (i - 1 >= 0 ? dp[i - 1][j] : 1ll << 60);
ll left = (j - 1 >= 0 ? dp[i][j - 1] : 1ll << 60);
dp[i][j] = min(a[i][j], min(up, left) + C);
Mi = min(Mi, min(up, left) + C + a[i][j]);
}
reverse(a.begin(), a.end());
}
cout << Mi << "\n";
}
E - Ring MST
有 \(n\)个顶点,\(m\) 种能够花费 \(c\) 连接顶点i ii和 \(i + a\) 的边,\(i\) 可以随便取, 边数无限。问使得图连通最少花费。如果不能连通输出 \(-1\)
把图连通,花费最小,考虑最小生成树的思想,先选择花费最小的边去连,如果两个顶点在同一集合,就不连。本题 \(n≤1e9\),不能建边做。但可以用类似的思想,先找出花费最小的边的种类,假设这种边可以连接 \(i\) 和 \(i + a\) , 然后一直使用这种边去连接顶点,最后无法再连的时候所有点就会被分成\(gcd(n, a)\) 个集合,即连接了 \(n - gcd(n, a)\)条边。继续用花费第二小的边连接顶点,可以发现当不能再连接的时候,所有点被分成\(gcd(n, a, a^{'})\)个集合,一直这样做,如果\(gcd\)能等于 \(1\) ,就说明已经连通了。
int main() {
cin.tie(nullptr)->sync_with_stdio(false);
int n, m;
cin >> n >> m;
pair<int, int>p[m + 1];
for (int i = 1; i <= m; ++i) cin >> p[i].second >> p[i].first;
sort(p + 1, p + 1 + m);
ll ans = 0;
for (int i = 1; i <= m; ++i) {
int d = __gcd(n, p[i].second);
ans += 1ll * (n - d) * p[i].first;
n = d;
}
cout << (n == 1 ? ans : -1);
}
F - Coprime Solitaire
不会
AtCoder Beginner Contest 210 (A~E)的更多相关文章
- AtCoder Beginner Contest 210题解
A B 过水,略... C 统计长度为k的区间的最多本质不同的数.用尺取法维护下左右指针就可以了.调了许久的原因是更新答案时出现了问题. 当我移动指针时,我们应该移动一个就更新一个,而不是将移动与更新 ...
- 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 我要崩溃,当时还以为是需要什么离散化的,原来是暴力,特么五层循环....我自己写怎么都 ...
随机推荐
- .NET Conf 2023 Chengdu - 成都会场即将到来!
12月9日 天府之国 不见不散 今年的.NET Conf 2023,中国区首次有两个会场举办Local Event,北京会场12月16日,成都会场12月9日.这是所有中国.NET开发者的节日,成都会场 ...
- freeswitch如何解决sip信令的NAT问题
概述 freeswitch是一款简单好用的VOIP开源软交换平台. 公网环境复杂多变,客户环境更是各种稀奇古怪的问题. fs在针对sip信令的NAT问题有针对性的参数设置. 本文讨论的范围限于fs的公 ...
- SpringCore完整学习教程4,入门级别
本章从第4章开始 4. Logging Spring Boot使用Commons Logging进行所有内部日志记录,但保留底层日志实现开放.为Java Util Logging.Log4J2和Log ...
- [ABC311G] One More Grid Task
Problem Statement There is an $N \times M$ grid, where the square at the $i$-th row from the top and ...
- [GDOIpj222B] 网页浏览
第二题 网页浏览 提交文件: webpage.cpp 输入文件: webpage.in 输出文件: webpage.out 时间空间限制: 1 秒, 256 MB 我们在上网时,从一个网页上的链接打开 ...
- SpringBoot整合阿里云OSS
1.创建一个service_ossspringboot项目 2.导入相关依赖 ...其他的依赖大家自行导入 <!-- 阿里云oss依赖 --> <dependency> < ...
- MOSS对话式大型语言模型
MOSS是复旦大学自然语言处理实验室发布的一种类似于ChatGPT的会话语言模型.MOSS能够按照用户的指示执行各种自然语言任务,包括回答问题.生成文本.摘要文本.生成代码等.MOSS还能够挑战错误的 ...
- ElasticSearch之Node query cache settings
对于filter查询,ElasticSearch提供了缓存查询结果的特性,当缓存中存在满足查询条件要求的数据时,直接从缓存中提取查询结果. 对于ElasticSearch节点,该节点上的所有shard ...
- C语言之小明的加减法
1.题目内容: 叛逆期的小明什么都喜欢反着做,连看数字也是如此(负号除外),比如: 小明会把1234它看成4321:把-1234看成-4321:把230看成032 (032=32):把-230看成-0 ...
- Feign源码解析:初始化过程(三)
背景 前面两篇讲了下,在一个典型的引入了feign.loadbalancer.nacos等相关依赖的环境中,会有哪些bean需要创建. 其中第一篇讲了非自动配置的bean,第二篇是自动配置的bean. ...