AtCoder Beginner Contest 163 (6/6)
比赛链接:Here
AB水题,
C - management
题意:给一棵 \(N(2\le N\le2e5)\) 个节点的有根树,求每个节点的儿子数。
思路:由于输入直接给的是每个节点的父节点,直接计数即可。
const int N = 2e5 + 10;
int a[N];
int main() {
ios::sync_with_stdio(false), cin.tie(nullptr);
int n; cin >> n;
for (int i = 1, x; i < n; ++i)
cin >> x, a[x] += 1;
for (int i = 1; i <= n; ++i) cout << a[i] << "\n";
}
D - Sum of Large Numbers
题意:当前有 \(N + 1\) 个整数:\(10^{100},10^{100}+1,...,10^{100}+N\),求取不少于 \(K\) 个数的和的可能值的数量(mod 1e9+7)。
数据范围:\(1\le N\le 2e5,1\le K\le N +1\)
思路:因为 \(10^{100}\) 明显很大,所以取 \(K\) 个总和不可能等于取 \(K+1\) 个数的综合,所以只需要枚举取多少个数即可。
对于取 \(K\) 个数可以求出取 \(K\) 个值的最小最大值,在这两个值之间的值都可以取到,个数就是最大值-最小值+1。
const int mod = 1e9 + 7;
int ans = 0;
void add(int &x, int y) {
x += y;
if (x >= mod) x -= mod;
if (x < 0) x += mod;
}
int cal(int l, int r) {
return 1ll * (l + r) * (r - l + 1) / 2 % mod;
}
int main() {
ios::sync_with_stdio(false), cin.tie(nullptr);
int n, k;
cin >> n >> k;
for (int i = k; i <= n + 1; i += 1)
add(ans, cal(n + 1 - i, n) - cal(0, i - 1) + 1);
cout << ans;
}
E - Active Infants
题意:有 \(N\) 个小孩,第 \(i\) 个孩子的位置为 \(i\),活跃值为 \(A_i\),现在将 \(N\) 个小孩重新排列,每个小孩获得的开心值为 \(A_i\) 与重新排列前后位置差的乘积,求最大可能的开心值总和。
数据范围:\(2\le N\le 2e3,1\le A_i\le 1e9\)
题解:可以发现将 \(A\) 较大的值放在边上更优,以A降序,然后就是一个区间dp,枚举当前值放左边、右边进行更新。
\(f[l][r]=\max \left(f[l+1][r]+A_{n o w} \times\left|p_{\text {now }}-l\right|, f[l][r-1]+A_{\text {now }} \times\left|p_{\text {now }}-r\right|\right)\)
const int N = 2e3 + 5;
ll f[N][N];
pair<int, int> p[N];
ll cal(int cnt, int l, int r) {
if (l > r) return 0;
if (~f[l][r]) return f[l][r];
ll ans = 1LL * p[cnt].first * abs(p[cnt].second - l) + cal(cnt + 1, l + 1, r);
ans = max(ans, 1LL * p[cnt].first * abs(p[cnt].second - r) + cal(cnt + 1, l, r - 1));
return f[l][r] = ans;
}
int main() {
int n; cin >> n;
for (int i = 1, x; i <= n; i++) {
scanf("%d", &x);
p[i] = {x, i};
}
sort(p + 1, p + n + 1, [](pair<int, int> a, pair<int, int> b) {
return a.first > b.first;
});
memset(f, -1, sizeof f);
cout << cal(1, 1, n);
return 0;
}
F - path pass i
题意:给一棵N个节点的无根树,每个节点有一个颜色属性c,对于每个颜色,求经过这种颜色的简单路径的数量。
数据范围:\(1\le c_i\le N\le 2e5\)
题解:把问题转换成不经过这种颜色的简单路径的数量,总数 \(f[N] = N*(N+1)/2\) 减去它即可。
其中不经过颜色 \(i\) 的简单路径的数量为:\(\sum\limits_{u !=v, u !=w, v !=w, c_{u}=c_{v}=i, \forall w \in \operatorname{path}(u, v), c_{u}=i} f[\operatorname{dis}(u, v)-1]_{\circ}\)
const int N = 2e5 + 5;
vector<int> G[N];
int C[N], num[N], sum[N];//num[i]代表i子树的节点数目,sum[i]代表以颜色为i的节点(其祖先没有颜色为i的节点)为根节点的子树大小总和
ll ans[N];
ll cal(int x) {
return 1LL * x * (x + 1) / 2;
}
void dfs(int u, int fa) {
int c = C[u], save = sum[c];
num[u] = 1;
for (auto v : G[u]) {
if (v == fa) continue;
int t = sum[c];
dfs(v, u);
int dt = sum[c] - t;
ans[c] -= cal(num[v] - dt);//num[v]-dt代表相邻两个节点之间的节点数
num[u] += num[v];
}
sum[c] = save + num[u];
}
int main() {
int n; cin >> n;
for (int i = 1; i <= n; i++) cin >> C[i];
for (int i = 1, u, v; i < n; i++) {
cin >> u >> v;
G[u].push_back(v);
G[v].push_back(u);
}
for (int i = 1; i <= n; i++)
ans[i] = cal(n);
dfs(1, -1);
for (int i = 1; i <= n; i++) {
int t = n - sum[i]; //多出来的节点还要减掉
ans[i] -= cal(t);
cout << ans[i] << "\n";
}
}
AtCoder Beginner Contest 163 (6/6)的更多相关文章
- AtCoder Beginner Contest 254(D-E)
Tasks - AtCoder Beginner Contest 254 D - Together Square 题意: 给定一个N,找出所有不超过N的 ( i , j ),使得( i * j )是一 ...
- AtCoder Beginner Contest 086 (ABCD)
A - Product 题目链接:https://abc086.contest.atcoder.jp/tasks/abc086_a Time limit : 2sec / Memory limit : ...
- AtCoder Beginner Contest 085(ABCD)
A - Already 2018 题目链接:https://abc085.contest.atcoder.jp/tasks/abc085_a Time limit : 2sec / Memory li ...
- AtCoder Beginner Contest 084(AB)
A - New Year 题目链接:https://abc084.contest.atcoder.jp/tasks/abc084_a Time limit : 2sec / Memory limit ...
- AtCoder Beginner Contest 083 (AB)
A - Libra 题目链接:https://abc083.contest.atcoder.jp/tasks/abc083_a Time limit : 2sec / Memory limit : 2 ...
- AtCoder Beginner Contest 163
比赛链接:https://atcoder.jp/contests/abc163/tasks A - Circle Pond 题意 由半径输出圆周长. 代码 #include <bits/stdc ...
- AtCoder Beginner Contest 264(D-E)
D - "redocta".swap(i,i+1) 题意: 给一个字符串,每次交换相邻两个字符,问最少多少次变成"atcoder" 题解: 从左到右依次模拟 # ...
- Atcoder Beginner Contest 121D(异或公式)
#include<bits/stdc++.h>using namespace std;int main(){ long long a,b; cin>>a>&g ...
- Atcoder Beginner Contest 156E(隔板法,组合数学)
#define HAVE_STRUCT_TIMESPEC #include<bits/stdc++.h> using namespace std; ; ; long long fac[N] ...
- Atcoder Beginner Contest 155E(DP)
#definde HAVE_STRUCT_TIMESPEC #include<bits/stdc++.h> using namespace std; ]; int main(){ ios: ...
随机推荐
- 给大家介绍一款强大的抓包代理工具--mitmproxy
最近工作中涉及到和app相关的测试工作,需要用到mock,特意网上查了些资料,发现有很多工具可以实现app的mock,但是经过我反复试用后,发现mitmproxy这个工具非常的强大 我认为mitmpr ...
- 2023年奔走的总结---吉特日化MES 项目趣事 篇一
终于又到了2023年的年末了,既有兴奋也有遗憾,兴奋的是这难熬的一年马上就要过去了,遗憾的是今年好像没有做成太多的事情.差不多180次的大交通记录,也再次刷新了奔走的记录,忙忙碌碌兜兜转转又去了不少地 ...
- skywalking自定义插件开发
skywalking是使用字节码操作技术和AOP概念拦截Java类方法的方式来追踪链路的,由于skywalking已经打包了字节码操作技术和链路追踪的上下文传播,因此只需定义拦截点即可. 这里以sky ...
- liunx系统sed命令使用
增 sed '$行数i 新增内容' 文件名在文件里某行上面新增内容 sed '$行数a 新增内容' 文件名在文件里某行下面新增内容 -i.bak对源文件进行修改并备份修改之前源文件 #在文件里第5行上 ...
- 单元测试平台搭建:sonarQube+sonarScanner+Jenkins+jacoco
单元测试平台搭建及结果分析 一.方案 需求目标:提高单元测试覆盖率和规范代码编写规范 选用工具:Sonarqube.sonarqube Scanner.Jenkins.jacoco 方案: 工程中引入 ...
- 印能捷添加了加密进程导出的pdf文件不加密(rename的类型未添加)
解决方法:用procmon监控下图的所有文件事件,查找rename的类型,然后右键SetRenameInfo点击Include,将查出来的类型添加到加密后缀中,如下图是一个无后缀的类型需要添加\NOE ...
- 【docker】docker中装Redis集群
一.搭建步骤 1.启动容器 #关闭防火墙 systemctl start docker 2.新建6个docker容器redis实例 docker run -d --name redis-node-1 ...
- vulnhub - tornado - wp
coverY: 0 tornado 信息收集 目标开放了80,22端口. 访问80网页,是默认页面: 目录枚举 用dirsearch没有什么发现,换gobuster发现了一个bluesky目录.访问如 ...
- Python——第五章:Traceback模块
traceback 模块提供了在程序中处理和分析异常时的工具,帮助开发人员更好地理解程序出现问题的原因. 使用 traceback.format_exc() 函数可以获取当前异常的堆栈信息.可以把错误 ...
- Ubuntu系统 安装 Zabbix Server 6.0
Zabbix6.0简介: zabbix6.0新特性 1.开箱即用的Zabbix server高可用群集 Zabbix server高可用防止硬件故障或计划维护期的停机: 原生选择加入HA群集配置 定义 ...