[Noi2014]魔法森林( 动态mst lct)
以前一直觉得lct特别难写,自从学了丽洁姐的lct之后,觉得lct居然能这么短,这个主程序能40行左右解决~~~~
这道嘛~~虽说能用spfa解决,但还是写下lct吧
把边按a值排序后一条一条插入并维护bmx值就行了= =
不过还是得膜拜云神在考场上a了这道题,我花了好久,自己还是太弱
NOIP就要来了,在这里祝自己RP++吧
毕竟升高二后,每天几乎都是怀着梦想睡觉的
希望这一年能不辜负我的愿望吧
向着最高点,冲吧!!!
CODE:
#include<cstdio>
#include<iostream>
#include<cstring>
#include<algorithm>
#include<map>
using namespace std;
#define maxn 101000
struct node{
node *ch[2],*p,*mx;bool rec;int val;
node(int v=0):val(v) {
rec=false;
p=ch[0]=ch[1]=NULL;
mx=this;
}
inline bool d();
inline bool isroot();
inline void update();
inline void relax();
}t[maxn];
inline bool node::d(){return p->ch[1]==this;}
inline bool node::isroot(){
return (p==NULL)||(p->ch[1]!=this&&p->ch[0]!=this);
}
inline void node::relax(){
if (!this) return;
if (!rec) return ;
if (ch[1]) ch[1]->rec^=1;
if (ch[0]) ch[0]->rec^=1;
swap(ch[1],ch[0]);
rec=0;
}
inline void node::update(){
if (!this) return ;
mx=this;
if (ch[0]&&ch[0]->mx->val > mx->val ) mx=ch[0]->mx;
if (ch[1]&&ch[1]->mx->val > mx->val ) mx=ch[1]->mx;
}
inline void rotate(node*u) {
node *v=u->p;
v->relax();u->relax();
bool d=u->d();
if (!v->isroot()) v->p->ch[v->d()]=u;
u->p=v->p;
if (u->ch[d^1]) u->ch[d^1]->p=v;
v->ch[d]=u->ch[d^1];
u->ch[d^1]=v;
v->p=u;
v->update(),u->update();
}
inline void splay(node *u) {
u->relax();
while (!u->isroot()){
if (u->p->isroot()) rotate(u);
else if (u->d()!=u->p->d()) rotate(u),rotate(u);
else rotate(u->p),rotate(u);
}
u->update();
}
inline node* expose(node *u) {
node *v;
for (v=NULL;u;v=u,u=u->p){
splay(u);
u->ch[1]=v;
u->update();
}
return v;
}
inline void evert(node *u) {
expose(u)->rec^=1;
splay(u);
}
inline void link(node *u,node *v) {
evert(u);
u->p=v;
expose(u);
}
inline void cut(node *u,node *v) {
evert(u);
expose(v);
splay(v);
v->ch[0]=u->p=NULL;
v->update();u->update();
}
inline int query(node *u,node *v) {
evert(u);
expose(v);
splay(v);
return v->mx->val;
}
int fa[maxn];
inline int find(int x) {
if (fa[x]!=x) fa[x]=find(fa[x]);
return fa[x];
}
int x[maxn],y[maxn],a[maxn],b[maxn],id[maxn];
bool cmp(int p,int q) {return a[p]<a[q];}
map<node*,int> ma;
int n,m;
int main(){
scanf("%d%d",&n,&m);
for (int i=1;i<=n;i++) fa[i]=i;
for (int i=1;i<=m;i++) {
scanf("%d%d%d%d",x+i,y+i,a+i,b+i);
id[i]=i;
}
sort(id+1,id+1+m,cmp);
int ans=0x7fffffff;
for (int i=1;i<=m;i++) {
if (x[id[i]]==y[id[i]]) continue;
node *u=&t[x[id[i]]],*v=&t[y[id[i]]];
if (find(x[id[i]])!=find(y[id[i]])) {
node *e=new node(b[id[i]]);
ma[e]=id[i];
link(u,e);
link (v,e);
fa[find(x[id[i]])]=find(y[id[i]]);
}else {
evert(u);
expose(v);
splay(v);
if (v->mx->val>b[id[i]]){
node *e=v->mx;
splay(e);
node *_u=&t[x[ma[e]]],*_v=&t[y[ma[e]]];
cut(e,_u);
cut(e,_v);
delete e;
e=new node(b[id[i]]);
ma[e]=id[i];
link (u,e);
link (v,e);
}
}
if (find(1)==find(n)) ans=min(ans,a[id[i]]+query(&t[1],&t[n]));
}
if (ans==0x7fffffff) ans=-1;
printf("%d\n",ans);
return 0;
}
[Noi2014]魔法森林( 动态mst lct)的更多相关文章
- bzoj 3669: [Noi2014]魔法森林 动态树
3669: [Noi2014]魔法森林 Time Limit: 30 Sec Memory Limit: 512 MBSubmit: 363 Solved: 202[Submit][Status] ...
- BZOJ3669: [Noi2014]魔法森林(瓶颈生成树 LCT)
Time Limit: 30 Sec Memory Limit: 512 MBSubmit: 3558 Solved: 2283[Submit][Status][Discuss] Descript ...
- [bzoj] 3669 NOI2014 魔法森林 || LCT
原题 copy一篇题解:原链接 将边按照a排序,然后从小到大枚举,加入图中. 在图中用lct维护一棵两点之间b最大值尽量小的生成树. 当加入一条边(u, v)时: 如果(u, v)不连通,则直接加入这 ...
- BZOJ 3669 [Noi2014]魔法森林(贪心+LCT)
[题目链接] http://www.lydsy.com/JudgeOnline/problem.php?id=3669 [题目大意] 给出一张图,每条边上有两个值ai和bi,现在需要求出一条1到N的路 ...
- BZOJ 3669: [Noi2014]魔法森林( LCT )
排序搞掉一维, 然后就用LCT维护加边MST. O(NlogN) ------------------------------------------------------------------- ...
- P2387 [NOI2014]魔法森林(LCT)
P2387 [NOI2014]魔法森林 LCT边权维护经典题 咋维护呢?边化为点,边权变点权. 本题中我们把边对关键字A进行排序,动态维护关键字B的最小生成树 加边后出现环咋办? splay维护最大边 ...
- loj2245 [NOI2014]魔法森林 LCT
[NOI2014]魔法森林 链接 loj 思路 a排序,b做动态最小生成树. 把边拆成点就可以了. uoj98.也许lct复杂度写假了..越卡常,越慢 代码 #include <bits/std ...
- bzoj 3669: [Noi2014]魔法森林 (LCT)
链接:https://www.lydsy.com/JudgeOnline/problem.php?id=3669 题面: 3669: [Noi2014]魔法森林 Time Limit: 30 Sec ...
- [NOI2014]魔法森林 LCT
题面 [NOI2014]魔法森林 题解 一条路径的代价为路径上的\(max(a[i]) + max(b[i])\),因为一条边同时有$a[i], b[i]$2种权值,直接处理不好同时兼顾到,所以我们考 ...
随机推荐
- UVa 374 - Big Mod
题目大意:计算R = BP mod M,根据模运算的性质计算. 正常计算会超时,可以用分治的思想降低时间复杂度.不过如果遇到00,结果...话说00的结果是1吗?忘了都... #include < ...
- react programming
So you're curious in learning this new thing called Reactive Programming, particularly its variant c ...
- Statemen接口对象
利用Statement接口实现数据表的更新和查询操作 -取得Statement接口对象:Statement createStatement(int resultSetType, int resultS ...
- Mysql和Oracle的一些语法区别
作为一个有追求的程序猿,当然要不断的学习,巴拉巴拉巴拉...好了,贴一个网址给大家,哈哈 MySQL与Oracle 差异比较:http://www.cnblogs.com/HondaHsu/p/364 ...
- apue- chapter 1 UNIX基础知识
1.C++实现ls命令 #include<dirent.h> #include<stdlib.h> #include<iostream> #include &quo ...
- WGCNA算法研究笔记
转自:http://www.gogoqq.com/ASPX/8390905/JournalContent/1303140588.aspx 研究了近半年的算法,记录下来给自己一个交代,也应该是考G前地最 ...
- OC-Objection 学习笔记之一:简单的开始
Objection 统一管理对象的引用问题,我想这就是这种技术的意义吧. 废话不说,咱们直接上步骤吧: 1:协议 我们的意识里要知道,一切围绕协议来进行. 下面的协议是一个视图的协议,该协议简单到不能 ...
- CSS中position属性( absolute | relative | static | fixed )详解
我们先来看看CSS3 Api中对position属性的相关定义: static:无特殊定位,对象遵循正常文档流.top,right,bottom,left等属性不会被应用. relative:对象遵循 ...
- eclipse 设置编辑窗口字体和背景颜色
最近装了几次系统,公司也换过电脑,所以换了几次eclipse,当然家里用的当然是最新版,公司就只有用几百年前的东西了 进入重点,我的编辑窗口习惯使用灰色的背景,感觉全白的不好看,还伤视力(没有科学依据 ...
- thinkPHP 视图
一.模板的使用 a.规则 模板文件夹下[TPL]/[分组文件夹/][模板主题文件夹/]和模块名同名的文件夹[Index]/和方法名同名的文件[index].html(.tp ...