比赛链接: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)的更多相关文章

  1. AtCoder Beginner Contest 210题解

    A B 过水,略... C 统计长度为k的区间的最多本质不同的数.用尺取法维护下左右指针就可以了.调了许久的原因是更新答案时出现了问题. 当我移动指针时,我们应该移动一个就更新一个,而不是将移动与更新 ...

  2. AtCoder Beginner Contest 100 2018/06/16

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

  3. AtCoder Beginner Contest 052

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

  4. AtCoder Beginner Contest 053 ABCD题

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

  5. AtCoder Beginner Contest 136

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

  6. AtCoder Beginner Contest 137 F

    AtCoder Beginner Contest 137 F 数论鬼题(虽然不算特别数论) 希望你在浏览这篇题解前已经知道了费马小定理 利用用费马小定理构造函数\(g(x)=(x-i)^{P-1}\) ...

  7. AtCoder Beginner Contest 076

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

  8. AtCoder Beginner Contest 079 D - Wall【Warshall Floyd algorithm】

    AtCoder Beginner Contest 079 D - Wall Warshall Floyd 最短路....先枚举 k #include<iostream> #include& ...

  9. AtCoder Beginner Contest 064 D - Insertion

    AtCoder Beginner Contest 064 D - Insertion Problem Statement You are given a string S of length N co ...

  10. AtCoder Beginner Contest 075 D - Axis-Parallel Rectangle【暴力】

    AtCoder Beginner Contest 075 D - Axis-Parallel Rectangle 我要崩溃,当时还以为是需要什么离散化的,原来是暴力,特么五层循环....我自己写怎么都 ...

随机推荐

  1. c# 高并发必备技巧(三)

    前面两篇文章主要是介绍了如何解决高并发情况下资源争夺的问题.但是现实的应用场景中除了要解决资源争夺问题,高并发的情况还需要解决更多问题,比如快速处理业务数据等, 本篇文章简要罗列一下与之相关的更多技术 ...

  2. C++ Qt开发:Slider滑块条组件

    Qt 是一个跨平台C++图形界面开发库,利用Qt可以快速开发跨平台窗体应用程序,在Qt中我们可以通过拖拽的方式将不同组件放到指定的位置,实现图形化开发极大的方便了开发效率,本章将重点介绍Slider滑 ...

  3. requests.exceptions.ProxyError问题解决方法

    出现这个问题是因为你系统上在使用代理,然后你的代理又是规则匹配的. https://stackoverflow.com/questions/36906985/switch-off-proxy-in-r ...

  4. Linux的文件系统,根目录rootfs结构

    文件系统fs 文件系统时操作系统用来管理文件的.fs=filesystem... 在linux中,一切皆为文件,这句话够经典了吧... linux中每个分区都是一个fs. FHS Linux下的Fil ...

  5. 2023总结与展望--Empirefree

    今年一篇博客都没写过了,好像完全在忙在工作和生活上面了,珍惜自我,保持热情,2024对我好点 目录 1. 年终总结 1.1.学习工作计划 1.2. 生活计划 1.3 个人总结 2. 未来展望 1. 年 ...

  6. Vue.js 原理分析

    本文内容提炼于<Vue.js设计与实现>,全书共 501 页,对 Vue.js 的设计原理从 0 到 1,循序渐进的讲解. 篇幅比较长,需要花些时间慢慢阅读,在合适的位置会给出在线示例以供 ...

  7. 2024年,在风云际会的编程世界里,窥探Java的前世今生,都说它穷途末路,我认为是柳暗花明!

    2024年,在风云际会的编程世界里,窥探Java的前世今生,都说它穷途末路,我认为是柳暗花明! 文编|JavaBuild 哈喽,大家好呀!我是JavaBuild,以后可以喊我鸟哥,嘿嘿!俺滴座右铭是不 ...

  8. Ubuntu 之 7zip使用

    1.安装 sudo apt-get install p7zip 2.压缩 7zr a xxx foldername 3.解压缩 7zr x xxx.7z 4.zip命令压缩文件夹 zip -qr xx ...

  9. 君子不玩物丧志,亦常以借物调心,网站集成二次元网页小组件(widget)石蒜模拟器,聊以赏玩

    传世经典<菜根谭>中有言曰:"徜徉于山林泉石之间,而尘心渐息:夷犹于诗书图画之内,而俗气潜消.故君子虽不玩物丧志,亦常借物调心."意思是,徜徉在林泉山石之间,能够摒弃杂 ...

  10. 面试官让列举Spring的事务会失效的场景,我说了8个

    本文分享自华为云社区<哪些场景下Spring的事务会失效?>,作者:冰 河 . 在日常工作中,如果对Spring的事务管理功能使用不当,则会造成Spring事务不生效的问题.而针对Spri ...