LGP7840题解
给出一种新的理解方式,本质上和正解是一致的。
首先我们现在已经有了一个森林,我们现在要给他加一条边,加哪一条边是最优的呢?
假设加的边是 \((u,v)\),那么 \(((d[u]+1)^2-d[u]^2) \times val[u]+((d[v]+1)^2-d[v]^2) \times val[v]\) 一定是最小的,也就是两个点的 \((2 \times d[u]+1) \times val[u]\) 分别是整个集合中的最小值和次小值,且不连通。
于是我们对每个联通块分别开一个堆,再对所有联通块开一个大堆就能 \(O(n\log^2n)\) 做了。(需要合并堆,优先队列启发式合并的总复杂度是 \(O(n\log^2n)\) 的,当然不嫌麻烦也可以写一颗左偏树)
对刚才的模型做一些改变,假设我们连接了在同一个联通块中的两个点又会是怎么样的呢?
假设我们有四个点 \(a,b,c,d\),连接 \((a,b)(c,d)\) 和 \((a,c)(b,d)\) 的权值是一样的,因为度数序列相同,接下来连接的两个点在对方的方案中都属于同一个联通块。
也就是说,两个点是否在同一个联通块中并不影响最终答案,因为我们是对其的度数进行了修改。
于是直接对所有点开一个大堆就好了,没必要分联通块什么的,复杂度 \(O(n\log n)\)。
#include<cstdio>
#include<queue>
typedef unsigned ui;
struct Node{
	ui d,val;
	inline bool operator<(const Node&it)const{
		return (2*d+1)*val>(2*it.d+1)*it.val;
	}
}now;std::priority_queue<Node>q;unsigned long long ans;
signed main(){
	ui i,n;scanf("%u",&n);now.d=1;
	for(i=1;i<=n;++i)scanf("%u",&now.val),ans+=now.val,q.push(now);
	for(i=1;i<=n-2;++i){
		now=q.top();q.pop();
		ans+=(2*now.d+1)*now.val;
		if(++now.d!=n)q.push(now);
	}
	printf("%llu",ans);
}
												
											LGP7840题解的更多相关文章
- 2016 华南师大ACM校赛 SCNUCPC 非官方题解
		
我要举报本次校赛出题人的消极出题!!! 官方题解请戳:http://3.scnuacm2015.sinaapp.com/?p=89(其实就是一堆代码没有题解) A. 树链剖分数据结构板题 题目大意:我 ...
 - noip2016十连测题解
		
以下代码为了阅读方便,省去以下头文件: #include <iostream> #include <stdio.h> #include <math.h> #incl ...
 - BZOJ-2561-最小生成树 题解(最小割)
		
2561: 最小生成树(题解) Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 1628 Solved: 786 传送门:http://www.lyd ...
 - Codeforces Round #353 (Div. 2) ABCDE 题解 python
		
Problems # Name A Infinite Sequence standard input/output 1 s, 256 MB x3509 B Restoring P ...
 - 哈尔滨理工大学ACM全国邀请赛(网络同步赛)题解
		
题目链接 提交连接:http://acm-software.hrbust.edu.cn/problemset.php?page=5 1470-1482 只做出来四道比较水的题目,还需要加强中等题的训练 ...
 - 2016ACM青岛区域赛题解
		
A.Relic Discovery_hdu5982 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Jav ...
 - poj1399 hoj1037 Direct Visibility 题解 (宽搜)
		
http://poj.org/problem?id=1399 http://acm.hit.edu.cn/hoj/problem/view?id=1037 题意: 在一个最多200*200的minec ...
 - 网络流n题 题解
		
学会了网络流,就经常闲的没事儿刷网络流--于是乎来一发题解. 1. COGS2093 花园的守护之神 题意:给定一个带权无向图,问至少删除多少条边才能使得s-t最短路的长度变长. 用Dijkstra或 ...
 - CF100965C题解..
		
求方程 \[ \begin{array}\\ \sum_{i=1}^n x_i & \equiv & a_1 \pmod{p} \\ \sum_{i=1}^n x_i^2 & ...
 
随机推荐
- linux 批量替换文件内容及查找某目录下所有包含某字符串的文件
			
转载请注明来源:https://www.cnblogs.com/hookjc/ 1. sed C代码 grep -rl matchstring somedir/ | xargs sed -i 's ...
 - 深入epoll
			
转载请注明来源:https://www.cnblogs.com/hookjc/ 一. 介绍Epoll 是一种高效的管理socket的模型,相对于select和poll来说具有更高的效率和易用性.传统的 ...
 - git rebase git merge
			
Git rebase 使用方法 1. git checkout feature 2. git rebase master feature 相当于git rebase master + git chec ...
 - 【转】Python中自定义可迭代对象
			
python 中内置的可迭代的对象有 list.tuple.set.dict 等,那么我们自己怎么定义一个可迭代的对象呢?先来段代码吧 import re import reprlib RE_WORD ...
 - 这个Dubbo注册中心扩展,有点意思!
			
今天想和大家聊聊Dubbo源码中实现的一个注册中心扩展.它很特殊,也帮我解决了一个困扰已久的问题,刚刚在生产中用了,效果很好,迫不及待想分享给大家. Dubbo的扩展性非常灵活,可以无侵入源码加载自定 ...
 - 数组中包含多个对象   按照对象中的时间进行排序   适用与Angular.js、Jquery、微信小程序等
			
LiveList.sort(this.compare('StartDate')) //StartData:需要排序的时间 compare: function (property) { ...
 - 帆软报表(finereport)  组合地图 保持系列名和值居中
			
自定义JavaScript代码,使用HTML解析 function(){ var name = this.name; var total = '<div style="width:10 ...
 - Spring Boot数据访问之多数据源配置及数据源动态切换
			
如果一个数据库数据量过大,考虑到分库分表和读写分离需要动态的切换到相应的数据库进行相关操作,这样就会有多个数据源.对于一个数据源的配置在Spring Boot数据访问之数据源自动配置 - 池塘里洗澡的 ...
 - VUE项目二级菜单刷新时404 nginx
			
原因:vue项目的路径时虚拟路径,并不存在,所以用nginx去请求请求不到,所以vue项目做了两部调整: 1.所有的请求后端接口地址前端写死 2.nginx里把所有的接口转发后端删掉,并添加以下内容 ...
 - 泛型种树(generic) 代码
			
再这个案例中我们,为什么要使用泛型约束 使用约束的原因 约束指定类型参数的功能和预期. 声明这些约束意味着你可以使用约束类型的操作和方法调用. 如果泛型类或 方法对泛型成员使用除简单赋值之外的任何操作 ...