补题链接:Here

1529A. Eshag Loves Big Arrays

【题意描述】

给定一个长度为 \(n\) 的正整数数组 \(a\) ,现在可执行若干次操作(可为 \(0\))

具体操作为:选定某个序列,删除严格大于序列的平均数的元素

请问最多能删去多少个元素

【解题思路】

观察一下样例容易发现,在若干次操作之后,一定是最小的元素留下,所以我们只需要统计最小值元素个数,然后输出 \(n - Mincnt\)

【AC 代码】

void solve() {
int n;
cin >> n;
int a[n + 1];
for (int i = 1; i <= n; ++i)cin >> a[i];
sort(a + 1, a + 1 + n);
int cnt = 0;
for (int i = 1; i <= n; ++i)if (a[i] == a[1])cnt++;
cout << n - cnt << "\n";
}

1529B. Sifid and Strange Subsequences

【题意描述】

先有一个长度为 \(n\) 的数组,定义“奇怪数组”:数组中任意两个元素的绝对值差值大于等于数组中的最大值,即 \(|a_i - a_j| >= Max\) ,请问由原数组中最大能选出多少个元素构成“奇怪数组”

【解题思路】

很容易证明一个奇怪的子序列不能包含一个以上的正元素。

所以最好选择所有的非正元素,现在我们最多只能选择一个正元素。

假设x是数组中最小的正元素。如果已经选取的集合中没有两个元素(如a和b)以a的方式存在,我们可以选取 \(|x−b |<x\)。

要检查这一点,我们只需对已经拾取的元素进行排序,并查看相邻元素对之间的差异。

复杂性:\(\mathcal{O}(nlog\ n)\)

【AC 代码】

void solve() {
int n;
cin >> n;
vector<int>a(n);
for (int &x : a)cin >> x;
sort(a.begin(), a.end());
int ans = 0, cnt0 = 0, cnt = 0;
for (int i = 0; i < n; ++i) {
if (a[i] < 0)ans++;
else if (a[i] == 0)cnt0++;
}
int res = ans + cnt0, Min = 1e9;
for (int i = 0; i + 1 < n; ++i) {
if (a[i + 1] > 0)break;
Min = min(Min, a[i + 1] - a[i]);
}
for (int i = 0; i < n; ++i)if (a[i] > 0 and a[i] <= Min)cnt++;
res = max(res, ans + (cnt0 > 0) + (cnt > 0));
cout << res << "\n";
}

1529C. Parsa's Humongous Tree

【题意描述】

给你一棵树,树上的每个节点 \(i\) 都有一个值域 \([l_i,r_i]\) ,我们需要从值域中确定一个值 \(a_i \in [l_i,r_i]\) ,而 \((u,v)\) 边权值则为$∣a_u − a_v∣ $ 。我们的目的就是要让所有的边权值之和最大。求出最大权值之和。

【解题思路】

感觉AtCoder上有一道很像的题

【AC 代码】

using ll = long long;
const int N = 1e5 + 10;
vector<int>g[N];
int a[N][2], n;
ll f[N][2];
void dfs(int v, int p) {
for (int s : g[v])
if (s != p) {
dfs(s, v);
f[v][0] += max(f[s][0] + abs(a[s][0] - a[v][0]), f[s][1] + abs(a[s][1] - a[v][0]));
f[v][1] += max(f[s][0] + abs(a[s][0] - a[v][1]), f[s][1] + abs(a[s][1] - a[v][1]));
}
}
void solve() {
cin >> n;
for (int i = 0; i < n; ++i)cin >> a[i][0] >> a[i][1];
for (int i = 0, u, v; i + 1 < n; ++i) {
cin >> u >> v;
--u, --v;
g[u].push_back(v);
g[v].push_back(u);
}
dfs(0, -1);
cout << max(f[0][0], f[0][1]) << "\n";
for (int i = 0; i < n; ++i) {
g[i].clear();
f[i][0] = f[i][1] = 0;
}
}

1529D. Kavi on Pairing Duty

【题意描述】

【解题思路】

设 \(dp_i\) 为 \(2i\) 点的良好配对数。

显然,答案是 \(dp_n\) 。

引理:表示x为与点1匹配的点。注意每个点p(\(x<p≤2n\) )属于长度等于 \([1,x]\) 长度的线段。

证明:假设某点p(\(x<p≤2n\) )与点q配对(q>p),因为[p,q]不在 \([1,x]\) 之内,所以它们的大小必须相等,配对才是好的。

为了计算dpn,考虑以下情况:

  • \(x>n\) :类似于上述引理,可以证明每个点p(\(1≤p≤2n−x+1\))与点i+x配对−1,剩余的未配对x−n−1个点形成一个连续的子阵列,该子阵列位于每个当前对内,因此它们可以在dpx中配对−n−1种方式。
  • \(x≤n\):在这种情况下,由于上述引理,所有的线段必须具有相同的长度,因此它们的长度必须是n的一个除数,在这种情况下,它们可以以D(n)的方式配对;其中D(n)是n的除数。

所以 \(dp_n=D(n)+∑^{n−1}_{i=0}dp_i\)。

注意 \(dp_0=dp_1=1\)。

【AC 代码】

const int N = 1e6 + 10, MOD = 998244353;
int n, dp[N], S;
void solve() {
cin >> n;
for (int i = 1; i <= n; i++) {
for (int j = i + i; j <= n; j += i) {
dp[j]++;
}
}
dp[0] = S = 1;
for (int i = 1; i <= n; i++) {
dp[i] = (dp[i] + S) % MOD;
S = (S + dp[i]) % MOD;
}
cout << dp[n] << endl;
}

Codeforces Round #722 (Div. 2) A~D题解的更多相关文章

  1. Codeforces Round #612 (Div. 2) 前四题题解

    这场比赛的出题人挺有意思,全部magic成了青色. 还有题目中的图片特别有趣. 晚上没打,开virtual contest打的,就会前三道,我太菜了. 最后看着题解补了第四道. 比赛传送门 A. An ...

  2. Codeforces Round #198 (Div. 2)A,B题解

    Codeforces Round #198 (Div. 2) 昨天看到奋斗群的群赛,好奇的去做了一下, 大概花了3个小时Ak,我大概可以退役了吧 那下面来稍微总结一下 A. The Wall Iahu ...

  3. Codeforces Round #672 (Div. 2) A - C1题解

    [Codeforces Round #672 (Div. 2) A - C1 ] 题目链接# A. Cubes Sorting 思路: " If Wheatley needs more th ...

  4. Codeforces Round #614 (Div. 2) A-E简要题解

    链接:https://codeforces.com/contest/1293 A. ConneR and the A.R.C. Markland-N 题意:略 思路:上下枚举1000次扫一遍,比较一下 ...

  5. Codeforces Round #610 (Div. 2) A-E简要题解

    contest链接: https://codeforces.com/contest/1282 A. Temporarily unavailable 题意: 给一个区间L,R通有网络,有个点x,在x+r ...

  6. Codeforces Round #611 (Div. 3) A-F简要题解

    contest链接:https://codeforces.com/contest/1283 A. Minutes Before the New Year 题意:给一个当前时间,输出离第二天差多少分钟 ...

  7. Codeforces Round #499 (Div. 2) D. Rocket题解

    题目: http://codeforces.com/contest/1011/problem/D This is an interactive problem. Natasha is going to ...

  8. Codeforces Round #499 (Div. 2) C Fly题解

    题目 http://codeforces.com/contest/1011/problem/C Natasha is going to fly on a rocket to Mars and retu ...

  9. Codeforces Round #198 (Div. 2)C,D题解

    接着是C,D的题解 C. Tourist Problem Iahub is a big fan of tourists. He wants to become a tourist himself, s ...

  10. Codeforces Round #579 (Div. 3) 套题 题解

    A. Circle of Students      题目:https://codeforces.com/contest/1203/problem/A 题意:一堆人坐成一个环,问能否按逆时针或者顺时针 ...

随机推荐

  1. VM离线安装Centos 8以及配置

    一.安装 1.预装准备 1.1. 硬件准备 物理内存:2G以上(这里指系统搭建所需占用空间) 物理外存:20G(这里指系统搭建所需占用空间) 1.2. 环境搭建准备 Window10系统电脑一台.Vm ...

  2. 耗时三年开源的H5商城,生产级代码实战

    waynboot-mall 商城项目是我从疫情开始初期着手准备开发的,到如今 2023 年底,已经过了 3 年多的时间. 从项目初期到现在,一个人持续迭代,修复漏洞,添加功能,经历了前端开发工具从 v ...

  3. [THUPC2022 决赛] rsraogps

    [THUPC2022 决赛] rsraogps 题目描述 给序列 \(a_1,\dots,a_n\),\(b_1,\dots,b_n\),\(c_1,\dots,c_n\), 定义区间 \([l,r] ...

  4. isAlive

    线程存活 当线程执行时显示线程存活 执行完毕为false

  5. C++ Qt开发:Charts绘制各类图表详解

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

  6. 文心一言 VS 讯飞星火 VS chatgpt (166)-- 算法导论13.1 6题

    六.用go语言,在一棵黑高为 k 的红黑树中,内部结点最多可能有多少个?最少可能有多少个? 文心一言: 红黑树是一种自平衡的二叉查找树,其中每个节点都有一个颜色属性,可以是红色或黑色.红黑树满足以下性 ...

  7. ubuntu frame 个人开发心得

    引言 有一次我在树莓派上安装 Ubuntu Core 我给创新创业项目开发一个可视化 gui 看板,用于展示数据. 然后我就找到了我需要的工具 Ubuntu Frame 初次尝试使用 Ubuntu F ...

  8. k8s卷管理-2

    目录 k8s卷管理-2 pv和pvc pv pv的定义 pvc pvc的定义 pv和pvc的绑定关系 手动指定pv与pvc绑定 pod使用pvc pod挂载pvc 访问模式的区别 k8s卷管理-2 之 ...

  9. 文心一言 VS 讯飞星火 VS chatgpt (52)-- 算法导论6.2 4题

    四.当i>A.heap-size/2 时,调用 MAX-HEAPIFY(A,i)会有什么结果? 文心一言: 当 i > A.heap-size/2 时,调用 MAX-HEAPIFY(A, ...

  10. SSH默认端口从22修改为其他端口

    1.在终端中使用root权限登录到您的Linux服务器. 2.打开终端,并使用适合您的文本编辑器(如vi.nano等)打开SSH配置文件.例如,通过运行以下命令之一: vi /etc/ssh/sshd ...