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

12.27ABC

比赛链接

AB

简单模拟即可,注意审清题意,手模小样例

C

想复杂了,用链表实现的,但实际上只需要维护一个栈就可以了,每加进来一个数就看一下栈顶的 4 个。

D

这种式子考虑将某一个变量的选择变成某一个东西的最优化问题,然后去维护这个东西。

比如这里我们枚举 \(x\),然后维护 \(C_i - B_i\) 的最大值,这样我们选择一个 y 就等效为把后面的 \(B\) 全部加上,然后选一个最大的 \(C_i - B_i\)

E

考虑到这个结构是基环树森林,我们可以考虑从这个视角来做。

建出来一颗基环树后,我们分别处理从一个点跳到环上(或者跳不到环上)和在环上跳多少次。

在树上跳到部分用倍增实现,环的部分我是先存下来环上的点,破环成链后维护前缀和。

当然如果你聪明一点,发现可以直接倍增做(大雾。

F

我们最初想法是,统计 \(\text{mex} = x\) 的路径条数 \(f(x)\),但这不好做,很难计算包含 0 到 \(x - 1\) 但不包含 \(x\) 的方案数。

trick 是,如果我计算 \(\text{mex} \geq x\) 的路径条数 \(g(i)\)。那么原本的答案是 \(\sum f(i) \times i\)\(\sum g(i)\) 是等价的。

写法上需要注意一些细节,比如如果你往上跳碰到的第一个在路径上的数是 0,要把 siz[0] 减去你所在这个子树的大小。

代码
#include <bits/stdc++.h>
using namespace std;namespace mlyy {#define int long longconst int N = 2e5 + 100;int n;vector<int> edge[N];int siz[N];int dfn[N];int f[N];int idx;int ans;void dfs(int u, int fa) {siz[u] = 1;f[u] = fa;dfn[u] = ++idx;for (int v : edge[u]) {if (v == fa) continue;dfs(v, u);siz[u] += siz[v];if (u == 0) {ans -= siz[v] * (siz[v] + 1) / 2;}}}int vis[N];void main() {cin >> n;for (int i = 1;i < n;i++) {int u, v;cin >> u >> v;edge[u].push_back(v);edge[v].push_back(u);}ans = n * (n + 1) / 2;dfs(0, -1);int x = 0, y = 0;int lst = 0;vis[0] = 1;// cout << ans << '\n';for (int i = 1;i < n;i++) {// cout << i << " " << ans << "\n";if (vis[i]) {ans += lst;continue;}int u = -1, v = -1;for (u = i;;u = f[u]) {// cout << u << " " << vis[u] << "\n";if (vis[u] == 1) break;vis[u] = 1;v = u;}if (u == x) x = i;else if (u == y) y = i;else break;// cout << v << "?\n";// cout << i << ":";// cout << x << ' ' << y << ": " << siz[y] - siz[v] << " " << siz[x] << "\n";if (u == 0) siz[0] -= siz[v];ans += (lst = siz[x] * siz[y]);//, cout << siz[x] * siz[y] << "\n";}cout << ans;}
}signed main() {mlyy::main();return 0;
}
http://www.jsqmd.com/news/155396/

相关文章:

  • 母子定律,准到吓人
  • 推荐阅读:深入理解C语言中的文件清理与系统资源管理
  • YOLO与Vault密钥管理集成:安全存储敏感配置信息
  • YOLO模型冷启动JIT预热:触发热点代码编译机制
  • 推荐阅读:清理C盘垃圾的CMD命令大全(15个实用CMD命令帮助您 ...
  • Springboot校园交友网站k73q9(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
  • CF 做题记录(12月)
  • STUN协议:NAT穿透的核心技术与应用实践
  • YOLO在文物修复的应用:破损区域智能识别辅助
  • 给老公改个嘎嘎甜的备注
  • Springboot新冠检测信息管理系统10m6v(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
  • YOLO模型训练资源使用报表:月度统计与成本分摊
  • YOLO与Jaeger分布式追踪集成:定位跨服务调用问题
  • python,如果定义了await funa()函数,哪几种情况下可以启动函数?
  • InfiniBand 网络管理探秘:子网管理器如何发现硬件并分配网络地址
  • GEO贴牌代理赋能AI搜索推荐,让品牌在智能问答中优先展现 - 源码云科技
  • YOLO模型灰度版本监控大盘:一站式观测核心指标
  • YOLO模型灰度发布期间紧急问题响应机制
  • 最近很火,你却不懂的新梗
  • YOLO与Spinnaker部署平台集成:多环境渐进式发布
  • YOLO模型训练任务依赖管理:有向无环图调度实现
  • YOLO模型灰度发布回滚演练:定期检验应急预案
  • YOLO模型灰度版本灰度结束后的用户通知
  • 计算机毕业设计Python+AI大模型新闻自动分类 新闻预测系统 新闻可视化 新闻爬虫 大数据毕业设计
  • Abaqus复合材料微观单胞RVE模型的周期性网格划分及E11,E22,E33,G12,G13...
  • 在微网的世界里,电能共享是个大话题。今天咱们聊聊如何用非对称纳什谈判来优化多微网间的电能共享,顺便加点代码,让大家感受一下这个高级玩意儿
  • 基于Matlab的MLP多层感知机多输入多输出预测:处理数据集与评估性能
  • YOLO与Kyverno策略引擎集成:K8s安全合规校验
  • 计算机毕业设计Python+AI大模型智能路线规划数据分析与个性化推荐系统 旅游路线推荐系统 旅游路线规划系统 大数据毕业设计
  • YOLO模型缓存雪崩防范:随机过期时间设置技巧