Triples of Cows

news2025/1/22 18:01:54

题目传送门

模拟赛 T 4 T4 T4 , 变换挺妙的, 而且感觉转换后问题就迎刃而解了

解法

强行模拟拆点重连边显然不行,会让图的边数达到 n 2 n^2 n2 级别的
——————————————————————————————————————————————————
考虑转化:在每一条边上新建一个虚点,
例如 第 i i i 条边 u − v u-v uv ,我们建一个虚点 n + i n+i n+i 并将原边变为两条边 u   −   n + i , n + i   −   v u\ -\ n+i,n+i \ - \ v u  n+i,n+i  v
发现转化后,对于删除 i i i 点的操作,只需将 i i i 删除并且合并虚点即可 ,图的形态仍是一颗树,就比较好处理了
——————————————————————————————————————————————————
考虑答案的计算 :需要分类讨论一下
首先我们记 原图编号 ≤ n \le n n 的点为实点(与虚点相对应), f u f_u fu u u u 的一级儿子的个数, g u g_u gu u u u 的二级儿子的个数, h u h_u hu u u u 的三级儿子的个数
对答案的贡献的情形分三种,记贡献为 Δ \Delta Δ
1.

在这里插入图片描述
2.
在这里插入图片描述
3.
在这里插入图片描述

将三种贡献加起来就有:
A n s = ∑ i = 1 n g i 2 − ∑ i = n + 1 n ∗ 2 + 1 f i ( f i − 1 ) ( f i + 1 ) − f i 2 + 2 f i h i Ans=\sum_{i=1}^{n} g_i^2 -\sum_{i=n+1}^{n*2+1} f_i (f_{i}-1)(f_i+1)-f_i^2+2f_ih_i Ans=i=1ngi2i=n+1n2+1fi(fi1)(fi+1)fi2+2fihi
合并虚点时用并查集维护并更新 f , g , h f,g,h f,g,h 的值

#include <algorithm>
#include <iostream>
#include <cstring>
#include <vector>

using ll = long long;
using namespace std;
const int N = 5e5 + 7;

int n;
vector<int> G[N];
ll f[N],g[N],h[N],fa[N],a[N];

int find(int x) {  return x==a[x]?x:a[x]=find(a[x]);  }

void dfs(int u,int ff) {
	fa[u]=ff;
	for(int v:G[u]) if(v!=ff) {
		dfs(v,u);
		if(u<=n) {
			g[u] += f[v] ;
		}else {
			++f[u] ;
			h[u] += g[v] ;
		}
	}
}

void work() {
	ll ans=0;
	for(int i=1;i<=n;i++) 
		ans += g[i]*g[i] ;
	for(int i=n+1;i<=(n<<1)-1;i++) 
		ans+=(f[i]*(f[i]+1)*(f[i]-1) - f[i]*f[i] + 2*f[i]*h[i]) , a[i] = i ;
	
	printf("%lld\n" , ans) ;
	for(int u=1;u<n;u++) {
		int x,y,z; x=find(fa[u]); y=fa[x]; z=find(fa[y]); // 最多影响往上3代
		ans-= g[u]*g[u] ;
		ans-=(f[x]*(f[x]+1)*(f[x]-1) - f[x]*f[x] + 2*f[x]*h[x]) ;
		ans-= g[y]*g[y];
		if(z) ans-=(f[z]*(f[z]+1)*(f[z]-1) - f[z]*f[z] + 2*f[z]*h[z]) ;
		--f[x],--g[y] ;
		if(z) --h[z];
		for(int v:G[u]) if(v!=fa[u]) {
			a[v] = x;
			f[x] += f[v]; h[x] -= f[v]; //三代变一代
			g[y] += f[v];
			h[x] += h[v];
			if(z) h[z]+=f[v] ;
			ans-=(f[v]*(f[v]+1)*(f[v]-1) - f[v]*f[v] + 2*f[v]*h[v]) ;
		}
		ans+= (f[x]*(f[x]+1)*(f[x]-1) - f[x]*f[x] + 2*f[x]*h[x]) ;
		ans+= g[y]*g[y];
		if(z) ans+=(f[z]*(f[z]+1)*(f[z]-1) - f[z]*f[z] + 2*f[z]*h[z]) ;
		
		printf("%lld\n" , ans) ;
	}
}

int main() {
    scanf("%d",&n);
    for(int i=1;i<n;i++) {
    	int u,v; scanf("%d%d",&u,&v);
    	G[u].push_back(n+i); G[n+i].push_back(v);
    	G[v].push_back(n+i); G[n+i].push_back(u);
	}
	dfs(n,0);
	work();
}

额,代码实现还是需要一点经验的,小看它了

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1190518.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

μC/OS-II---内核:任务Task

目录 内核&#xff1a;多任务&#xff08;ucos_ii.h文件的函数&#xff09;Task创建Task创建&#xff08;扩展&#xff09;Task删除/请求删除Task改变Task优先级Task挂起和恢复Task信息获取Task调度器上锁和开锁 内核&#xff1a;多任务&#xff08;ucos_ii.h文件的函数&#x…

计算机底层的秘密 摘抄笔记

https://www.bookstack.cn/read/webxiaohua-gitbook/README.md 大部分是摘抄 机器指令需要加载到内存中执行&#xff0c;因此需要记录下内存的起始地址和长度&#xff1b;同时要找到函数的入口地址并写到PC寄存器中&#xff0c;想一想这是不是需要一个数据结构来记录下这些信…

springCloud和dubbo的区别

两者都是现在主流的微服务框架&#xff0c;但却存在不少差异&#xff1a; 初始定位不同&#xff1a;SpringCloud定位为微服务架构下的一站式解决方案&#xff1b;Dubbo 是 SOA 时代的产物&#xff0c;它的关注点主要在于服务的调用和治理生态环境不同&#xff1a;SpringCloud依…

Bean——IOC(Github上有代码)

源码 https://github.com/cmdch2017/Bean_IOC.git 获取Bean对象 BeanFactory Bean的作用域 第三方Bean需要用Bean注解 比如消息队列项目中&#xff0c;需要用到Json的消息转换器&#xff0c;这是第三方的Bean对象&#xff0c;所以不能用Component&#xff0c;而要用Bean …

C语言---插入排序、希尔排序、冒泡排序、选择排序、快速排序简单介绍

文章目录 插入排序希尔排序冒泡排序选择排序快速排序 本文主要介绍用C语言实现的一些排序方法&#xff0c;有插入排序、希尔排序、冒泡排序、选择排序和快速排序&#xff0c;文章中给出的例子都是按照升序排列的。 插入排序 若数组只有一个元素&#xff0c;自然不用排序&#…

[C]环境(0/0)→ 环境配置

这里写目录标题 0x00 额环境下载解压 0x00 额 写了那么多C的入门&#xff0c;就是没写C语言的环境配置&#xff0c;乘此机会写了吧。 环境下载 直接在我这下载就好了&#xff0c;毕竟用了挺久没啥问题的 C语言环境&#xff08;gcc version 8.1.0&#xff09; 解压 最后得到…

【JAVA学习笔记】66 - 本章作业(IO流)

项目代码 https://github.com/yinhai1114/Java_Learning_Code/tree/main/IDEA_Chapter19/src/com/yinhai/homework 1.使用File类和FileWriter类 (1)在判断e盘下是否有文件夹mytemp&#xff0c;如果没有就创建mytemp public class Homework01 {public static void main(String…

大数据技术从业者注意了!使用代理IP时避开这些误区

作为一名专业的大数据从业者&#xff0c;我经常需要使用HTTP代理IP进行数据爬取工作。在这个过程中&#xff0c;我积累了一些关于使用代理IP的经验&#xff0c;同时也发现了一些新手常见的误区&#xff0c;这些误区可能会影响你的工作的效率和数据准确性。我将分享一些关于使用…

使用超融合,网络交换机如何选型与配置?

很多用户在部署超融合集群时&#xff0c;都会关注网络交换机的选型与配置。我们在这篇文章中整理了一些关于网络交换机的常见提问&#xff0c;并邀请 SmartX 技术专家进行了详细解答。 Q1. 超融合架构下&#xff0c;网络交换机是如何部署的&#xff1f;需要多少台交换机&#x…

黑芝麻智能与香港科技园签订合作备忘录,迈向全球化发展新阶段

11月6日&#xff0c;黑芝麻智能与香港科技园公司举行合作签约仪式&#xff0c;双方将合力推动黑芝麻智能香港科技创新研发中心在科技园落地&#xff0c;并促进园区打造车规级高性能智能汽车计算芯片平台。黑芝麻智能首席市场营销官杨宇欣、香港科技园公司首席企业发展总监姚庆良…

学妹刚毕业那天,我连夜用Python采集了上万份岗位数据,只为给她找一份好工作

记得学妹刚毕业那天&#xff0c;为了不让学妹毕业就失业&#xff0c;连夜我就用Python采集了上万份岗位&#xff0c;分析出最合适她的工作。 为此&#xff0c;学妹连夜来我家表示感谢&#x1f60d; 我们开始今天的正题吧 首先要准备这些 软件 Python 3.8Pycharm 模块使用 …

棱镜七彩加入UOS主动安全防护计划(UAPP),共建信创生态

近日&#xff0c;在统信UOS主动安全防护计划&#xff08;UAPP&#xff09;技术沙龙上&#xff0c;2023年度第二期UAPP合作伙伴授牌发布仪式正式举行。棱镜七彩作为国内专注开源安全与软件供应链安全的创新型厂商&#xff0c;正式获得官方授牌&#xff0c;成为 UAPP 成员单位。 …

2021年09月 Python(四级)真题解析#中国电子学会#全国青少年软件编程等级考试

Python等级考试(1~6级)全部真题・点这里 一、单选题(共25题,每题2分,共50分) 第1题 对于数列3,8,11,15,17,19,25,30,44,采用“二分查找”法查找8,需要查找多少次? A:5 B:4 C:3 D:2 答案:D 按二分查找法的规律,每次先查找中间值,进行比较。 第2题…

在vue中如果头像为空时用姓名第一个字当头像

业务场景:当个人资料或者用户头像没有图片时&#xff0c;默认使用户名字中第一个汉字做头像。 效果图&#xff1a; 完整代码&#xff1a; <el-avatarsize"large" style"width: 45px; height: 45px; line-height: 45px; font-size: 24px"v-if"…

无需开发,精臣云可轻松连接用户运营、广告推广等行业应用

精臣智慧标识科技有限公司简介 武汉精臣智慧标识科技有限公司&#xff0c;是国内便携式标签打印机创新品牌和实物管理解决方案服务商。在物品标签还处在繁琐的PC打印时代&#xff0c;精臣公司便创造性地从智能便携角度出发&#xff0c;顺应移动互联时代趋势&#xff0c;推出了…

HarmonyOS开发:回调实现网络的拦截

前言 上一篇文章&#xff0c;分享了一个基于http封装的一个网络库&#xff0c;里面有一个知识点&#xff0c;在初始化的时候&#xff0c;可以设置请求头拦截和请求错误后的信息的拦截&#xff0c;具体案例如下&#xff1a; Net.getInstance().init({netErrorInterceptor: new M…

1995-2020年全国各省二氧化碳排放量面板数据

1995-2020年全国各省二氧化碳排放面板数据 1、时间&#xff1a;1995-2020 2、范围&#xff1a;全国、30省 3、来源&#xff1a;中国能源统计NJ 4、指标&#xff1a; 统计年度、地区代码、地区名称、煤炭二氧化碳排放量、焦炭二氧化碳排放量、原油二氧化碳排放量、汽油二氧…

苹果Apple ID忘了或者咨询其他问题如何让苹果客服打电话给你

环境&#xff1a; iPhone11 Apple ID 问题描述&#xff1a; 苹果Apple ID忘了或者咨询其他问题如何让苹果客服打电话给你 上次公司苹果设备&#xff0c;忘了激活锁的账户密码要向苹果申请解锁&#xff0c;打了很长电话&#xff0c;平时语音超套餐了&#xff0c;想着让他们…

python 删除特定字符所在行

嗨喽&#xff0c;大家好呀~这里是爱看美女的茜茜呐 查询文件中含有特殊字符串的行 #!/usr/bin/python # -*- coding:utf-8 -*- import re file1 open(test.txt,r) istxt re.compile(r.*if.*,re.I) for line in file1.readlines():line line.strip()ifstr re.findall(istxt…

【好书推荐】计算机考研精炼1000题——考研408不可或缺

《计算机考研精炼1000题》简介 本书根据最新《全国硕士研究生招生考试计算机学科专业基础考试大纲》编写。参考过去十多年的真题&#xff0c;本书精心编排了单项选择题和综合应用题&#xff0c;共约1000道&#xff08;分为上下两册&#xff0c;共24章。上册&#xff08;1&#…