BZOJ2001: [Hnoi2010]City 城市建设
题目:http://www.lydsy.com/JudgeOnline/problem.php?id=2001
cdq分治+重建图。
可以保留当前一定会被选的非修改边然后把点缩起来。这样的话每次点数至多只有r-l+1个,边数只有2*(r-l+1)-1个(生成树+修改边)。
时间复杂度O(nlog^2(n))
#include<cstring>
#include<iostream>
#include<cstdio>
#include<algorithm>
#define rep(i,l,r) for (int i=l;i<=r;i++)
#define down(i,l,r) for (int i=l;i>=r;i--)
#define clr(x,y) memset(x,y,sizeof(x))
#define maxn 50050
#define ll long long
#define inf 1000000000
using namespace std;
struct data{int x,y;ll z;int k,id;
}a[][maxn];
struct node{int k;ll w;int id;
}b[maxn];
int fa[maxn],pos[maxn],p[maxn],n,m,Q;
ll dis[maxn];
int read(){
int x=,f=; char ch=getchar();
while (!isdigit(ch)) {if (ch=='-') f=-; ch=getchar();}
while (isdigit(ch)) {x=x*+ch-''; ch=getchar();}
return x*f;
}
int find(int x){
if (fa[x]==x) return x;
return fa[x]=find(fa[x]);
}
bool cmp(data a,data b){
return a.z<b.z;
}
void cdq(int dep,int l,int r,int n,int m,ll ans){
rep(i,,m){
data &c=a[dep][i],&c2=a[dep-][i];
a[dep][i]=(data){c2.x,c2.y,dis[c2.id],,c2.id};
pos[c.id]=i;
}
//当l=r,计算答案,直接赋值当前修改边。
if (l==r){
data &c=a[dep][pos[b[l].k]]; c.z=dis[c.id]=b[l].w;
rep(i,,n) fa[i]=i;
sort(a[dep]+,a[dep]++m,cmp);
rep(i,,m){
int x=find(a[dep][i].x),y=find(a[dep][i].y);
if (x!=y) fa[x]=y,ans+=a[dep][i].z;
}
printf("%lld\n",ans);
return;
}
//删边,如果k=0,那么这是一条无用的边。
rep(i,l,r) a[dep][pos[b[i].k]].k=;
rep(i,,n) fa[i]=i;
sort(a[dep]+,a[dep]++m,cmp);
rep(i,,m) if (a[dep][i].k==){
int x=find(a[dep][i].x),y=find(a[dep][i].y);
if (x!=y) fa[x]=y,a[dep][i].k=;
}
//删点,找出必连边(k=3)
rep(i,,m) if (a[dep][i].k==) a[dep][i].z=-inf;
rep(i,,n) fa[i]=i;
sort(a[dep]+,a[dep]++m,cmp);
rep(i,,m) if (a[dep][i].k!=){
int x=find(a[dep][i].x),y=find(a[dep][i].y);
if (x!=y) {
fa[x]=y;
if (a[dep][i].k!=) a[dep][i].k=;
}
}
//重建,把必连边(k=3)取为答案,将两端点缩为一个点。
rep(i,,n) fa[i]=i;
rep(i,,m) if (a[dep][i].k==){
data &c=a[dep][i];
int x=find(c.x),y=find(c.y);
if (x!=y) fa[x]=y, ans+=c.z;
}
int nn=,nm=;
rep(i,,n) p[i]=;
rep(i,,n) if (!p[find(i)]) p[find(i)]=++nn;
rep(i,,m) if (a[dep][i].k!=){
int x=find(a[dep][i].x),y=find(a[dep][i].y);
data &c=a[dep][i];
if (x!=y) a[dep][++nm]=(data){p[x],p[y],c.z,c.k,c.id};
}
int mid=(l+r)/;
cdq(dep+,l,mid,nn,nm,ans);
cdq(dep+,mid+,r,nn,nm,ans);
}
int main(){
n=read(); m=read(); Q=read();
int x,y; ll z;
rep(i,,m){
x=read(); y=read(); z=read();
a[][i]=(data){x,y,z,,i};
}
rep(i,,Q){
x=read(); y=read();
b[i]=(node){x,y,i};
}
rep(i,,m) dis[a[][i].id]=a[][i].z;
cdq(,,Q,n,m,);
return ;
}
BZOJ2001: [Hnoi2010]City 城市建设的更多相关文章
- BZOJ2001 [Hnoi2010]City 城市建设 CDQ分治
2001: [Hnoi2010]City 城市建设 Time Limit: 20 Sec Memory Limit: 162 MB Description PS国是一个拥有诸多城市的大国,国王Lou ...
- BZOJ2001 [Hnoi2010]City 城市建设 【CDQ分治 + kruskal】
题目链接 BZOJ2001 题解 CDQ分治神题... 难想难写.. 比较朴素的思想是对于每个询问都求一遍\(BST\),这样做显然会爆 考虑一下时间都浪费在了什么地方 我们每次求\(BST\)实际上 ...
- 【BZOJ2001】 [Hnoi2010]City 城市建设
BZOJ2001 [Hnoi2010]City 城市建设 Solution 我们考虑一下这个东西怎么求解? 思考无果...... 咦? 好像可以离线cdq,每一次判断一下如果这条边如果不选就直接删除, ...
- BZOJ 2001: [Hnoi2010]City 城市建设
2001: [Hnoi2010]City 城市建设 Time Limit: 20 Sec Memory Limit: 162 MBSubmit: 1132 Solved: 555[Submit][ ...
- 【bzoj2001】 Hnoi2010—City 城市建设
http://www.lydsy.com/JudgeOnline/problem.php?id=2001 (题目链接) 题意 给出一张无向图,$m$组操作,每次修改一条边的权值,对于每次操作输出修改之 ...
- 2001: [Hnoi2010]City 城市建设 - BZOJ
DescriptionPS国是一个拥有诸多城市的大国,国王Louis为城市的交通建设可谓绞尽脑汁.Louis可以在某些城市之间修建道路,在不同的城市之间修建道路需要不同的花费.Louis希望建造最少的 ...
- 【刷题】BZOJ 2001 [Hnoi2010]City 城市建设
Description PS国是一个拥有诸多城市的大国,国王Louis为城市的交通建设可谓绞尽脑汁.Louis可以在某些城市之间修建道路,在不同的城市之间修建道路需要不同的花费.Louis希望建造最少 ...
- [HNOI2010]CITY 城市建设
问题: 给一张图,支持边长度修改,求MST 题解: 自己想就想不到了.. 考虑cdq分治 1.首先求出一定有用的边 对于未处理的边,全部设为-INF,求一次MST,出现在MST上的边一定最终出现在后面 ...
- 【HNOI2010】城市建设(对时间分治 & Kruskal)
Description \(n\) 个点 \(m\) 条边的带边权无向图.\(q\) 次操作,每次修改一条边的权值. 求每次修改后的最小生成树的边权和. Hint \(1\le n\le 2\time ...
随机推荐
- 个人的MySql配置总结
lower_case_table_names参数是用来设置MySQL是否让Schema和数据表大小写敏感,我测试的是在查询界面和MySQL控制台界面无法改变它的值,要在配置文件中改变(先关闭服务),一 ...
- adb指令介绍
一.adb命令格式为:adb [-d|-e|-s <serialNumber>] <command> 1.adb devices :列出当前电脑所连接的所有安卓设备 2.adb ...
- COM_第四讲_保存GUID_优化使用代码
优化以前的代码,让使用者更方便 一丶 优化思路 1.我们可以将我们写的GUID(类工厂的ID)保存到注册表中,并且保存一下DLL的文件路径,遍历注册表去DLL路径即可. 2.每个类工厂我们就要使用一个 ...
- php多语言切换---转载
文件内容: /include/language.php <?php $languages = array (); $languages ['zh-cn'] ["name"] ...
- rabbitMQ教程(三) spring整合rabbitMQ代码实例
一.开启rabbitMQ服务,导入MQ jar包和gson jar包(MQ默认的是jackson,但是效率不如Gson,所以我们用gson) 二.发送端配置,在spring配置文件中配置 <?x ...
- 操作Frame和IFrame中页面元素
HTML <iframe> 标签 定义:iframe 元素会创建包含另外一个文档的内联框架(即行内框架). frame标签有frameset.frame.iframe三种,frameset ...
- python爬虫——建立IP池,将可用IP存放到redis
直接上代码,每行代码后面都有注释 import urllib.request import urllib import re import time import random import sock ...
- Webpack 2 视频教程 011 - Webpack2 中加载 CSS 的相关配置与实战
原文发表于我的技术博客 这是我免费发布的高质量超清「Webpack 2 视频教程」. Webpack 作为目前前端开发必备的框架,Webpack 发布了 2.0 版本,此视频就是基于 2.0 的版本讲 ...
- JavaScript的DOM编程--07--节点的属性
节点的属性: 1). nodeName: 代表当前节点的名字. 只读属性. 如果给定节点是一个文本节点, nodeName 属性将返回内容为 #text 的字符串 2). nodeType:返回一个整 ...
- 7、正确的赚钱方式 - CEO之公司管理经验谈
创业者创办公司,最初的目的就是为了赚钱,而普通的员工来公司上班,为了生计,也是以赚钱为目的.今天我们就讲讲正确的赚钱方式. 一.去公司上班: 来公司上班是第一个主要的赚钱方式.不管是员工还是公司领导, ...