当前位置: 首页 > news >正文

E. Count Paths

题目

题解:

#include <bits/stdc++.h>#define forn(i, n) for (int i = 0; i < int(n); i++)using namespace std;int n;
vector<int> a;
vector<vector<int>> g;long long ans;
vector<map<int, int>> cnt;void dfs(int v, int p = -1){int bst = -1;for (int u : g[v]) if (u != p){dfs(u, v);if (bst == -1 || cnt[bst].size() < cnt[u].size())bst = u;}for (int u : g[v]) if (u != p && u != bst){for (auto it : cnt[u]){int x = it.first, y = it.second;if (x != a[v]) ans += cnt[bst][x] * 1ll * y;cnt[bst][x] += y;}}if (bst != -1) swap(cnt[bst], cnt[v]);ans += cnt[v][a[v]];cnt[v][a[v]] = 1;
}int main() {cin.tie(0);ios::sync_with_stdio(false);int t;cin >> t;while (t--){int n;cin >> n;a.resize(n);forn(i, n) cin >> a[i];g.assign(n, {});forn(_, n - 1){int v, u;cin >> v >> u;--v, --u;g[v].push_back(u);g[u].push_back(v);}ans = 0;cnt.assign(n, {});dfs(0);cout << ans << '\n';}return 0;
}

http://www.lryc.cn/news/460860.html

相关文章:

  • 集合论(ZFC)之良创关系(Well-Founded Relation)
  • centos 安装达梦数据库
  • 《Windows PE》6.4.1 无 DLL远程注入
  • 浙大数据结构:10-排序6 Sort with Swap(0, i)
  • 基于vue框架的的爱心捐赠物资信息系统85gsu(程序+源码+数据库+调试部署+开发环境)系统界面在最后面。
  • AI对抗AI:如何应对自动化攻击新时代?
  • 【微服务】微服务注册:构建灵活的服务管理机制
  • AsyncTask的工作原理和缺陷
  • 【React】事件绑定的方式
  • Android ImageView scaleType使用
  • 【PhpSpreadsheet】ThinkPHP5+PhpSpreadsheet实现批量导出数据
  • Python剪辑视频
  • LabVIEW提高开发效率技巧----高效文件I/O
  • 影刀RPA接口_查询应用主流程参数结构
  • 2d实时数字人聊天语音对话使用案例,对接大模型
  • LeetCode | 69.x的平方根
  • 使用Windows创建一个MFC应用【带界面】
  • springboot整合lombok
  • 使用Arcgis批量自动出图
  • Web Worker加载外部文件实践
  • 2024年中国工业大模型行业发展研究报告|附43页PDF文件下载
  • 99. UE5 GAS RPG 被动技能实现
  • U盘装系统,使用U盘启动,提示需要装驱动
  • gaussdb 主备 8 数据库安全学习
  • React 基础阶段学习计划
  • FFmpeg的简单使用【Windows】--- 指定视频的时长
  • 请求参数中字符串的+变成了空格
  • 前端开发攻略---使用AJAX监控网络请求进度
  • [已解决]DockerTarBuilder永久解决镜像docker拉取异常问题
  • 机器学习实战27-基于双向长短期记忆网络 BiLSTM 的黄金价格模型研究