暖气来啦~

动态树维护最大生成树裸题

#include<iostream>
#include<cstdio>
#include<cstdlib>
#include<cstring>
#include<cmath>
#include<algorithm>
using namespace std;
inline int read()
{
int x=,f=;char ch=getchar();
while(ch<''||ch>''){if(ch=='-')f=-;ch=getchar();}
while(ch>=''&&ch<=''){x=x*+ch-'';ch=getchar();}
return x*f;
}
const int maxn=;
int es[maxn][];
int n,m;
int rt,Size;
struct LCT
{
int son[maxn][],f[maxn],val[maxn],size[maxn],cnt[maxn],rev[maxn],st[maxn];
int t[maxn],len[maxn],mn[maxn],sum[maxn];
inline void update(int x)
{
int &o=x,lch=son[x][],rch=son[x][];
mn[o]=x;sum[o]=len[o];
if(son[x][])
{
if(t[mn[lch]]<t[mn[x]]) mn[o]=mn[lch];
sum[o]+=sum[lch];
}
if(son[x][])
{
if(t[mn[rch]]<t[mn[x]]) mn[o]=mn[rch];
sum[o]+=sum[rch];
}
}
inline int isroot(int x){return son[f[x]][]!=x && son[f[x]][]!=x;}
inline void rotate(int x)
{
int y=f[x],z=f[y],l,r;
if(son[y][]==x)l=;
else l=;r=l^;
if(!isroot(y))
{
if(son[z][]==y)son[z][]=x;
else son[z][]=x;
}
f[x]=z;f[y]=x;f[son[x][r]]=y;
son[y][l]=son[x][r];son[x][r]=y;
update(y);
}
inline void pushdown(int id)
{
int lch=son[id][],rch=son[id][];
if(rev[id])
{
rev[id]^=;rev[lch]^=;rev[rch]^=;
swap(son[id][],son[id][]);
}
}
inline void Splay(int x)
{
int top=;st[++top]=x;
for(int i=x;!isroot(i);i=f[i])st[++top]=f[i];
for(int i=top;i;i--)pushdown(st[i]);
while(!isroot(x))
{
int y=f[x],z=f[y];
if(!isroot(y))
{
if(son[y][]==x^son[z][]==y)rotate(x);
else rotate(y);
}
rotate(x);
}
update(x);
}
inline void access(int x)
{
int t=;
while(x)
{
Splay(x);
son[x][]=t;
t=x;
x=f[x];
update(x);
}
}
inline void makert(int x){access(x);Splay(x);rev[x]^=;}
inline void link(int x,int y){makert(x);f[x]=y;}
inline void cut(int x,int y){makert(x);access(y);Splay(y);son[y][]=f[x]=;update(y);}
inline int findf(int x)
{
access(x);Splay(x);
int y=x;
while(son[y][])y=son[y][];
return y;
}
}Tree;
char opt[];
int main()
{
scanf("%d%d",&n,&m);
int k,x,y,z;
for(int i=;i<=n;i++)Tree.t[i]=;
while(m--)
{
scanf("%s",opt);
if(opt[]=='f')
{
scanf("%d%d%d",&z,&x,&y);z++,x++,y++;
z+=n;es[z][]=x,es[z][]=y;
scanf("%d%d",&Tree.t[z],&Tree.len[z]);
if(Tree.findf(x)!=Tree.findf(y)){Tree.link(z,x),Tree.link(z,y);}
else
{
Tree.makert(x);Tree.access(y);Tree.Splay(y);
if(Tree.t[Tree.mn[y]]<Tree.t[z])
{
k=Tree.mn[y];Tree.cut(k,es[k][]);Tree.cut(k,es[k][]);
Tree.link(z,x),Tree.link(z,y);
}
}
}
else if(opt[]=='m')
{
scanf("%d%d",&x,&y);x++,y++;
if(Tree.findf(x)!=Tree.findf(y))puts("-1");
else
{
Tree.makert(x);Tree.access(y);Tree.Splay(y);
printf("%d\n",Tree.sum[y]);
}
}
else
{
scanf("%d%d",&x,&y);x++;
x+=n;Tree.Splay(x);Tree.len[x]=y;Tree.update(x);
}
}
}

uoj279温暖会指引我们前行的更多相关文章

  1. UOJ #274. 【清华集训2016】温暖会指引我们前行 [lct]

    #274. [清华集训2016]温暖会指引我们前行 题意比较巧妙 裸lct维护最大生成树 #include <iostream> #include <cstdio> #incl ...

  2. 【BZOJ4736】温暖会指引我们前行(Link-Cut Tree)

    [BZOJ4736]温暖会指引我们前行(Link-Cut Tree) ##题面 神TM题面是UOJ的 题解 LCT傻逼维护最大生成树 不会的可以去做一做魔法森林 #include<iostrea ...

  3. UOJ_274_[清华集训2016]温暖会指引我们前行_LCT

    UOJ_274_[清华集训2016]温暖会指引我们前行_LCT 任务描述:http://uoj.ac/problem/274 本题中的字典序不同在于空串的字典序最大. 并且题中要求排序后字典序最大. ...

  4. 【UOJ274】【清华集训2016】温暖会指引我们前行 LCT

    [UOJ274][清华集训2016]温暖会指引我们前行 任务描述 虽然小R住的宿舍楼早已来了暖气,但是由于某些原因,宿舍楼中的某些窗户仍然开着(例如厕所的窗户),这就使得宿舍楼中有一些路上的温度还是很 ...

  5. [UOJ#274][清华集训2016]温暖会指引我们前行

    [UOJ#274][清华集训2016]温暖会指引我们前行 试题描述 寒冬又一次肆虐了北国大地 无情的北风穿透了人们御寒的衣物 可怜虫们在冬夜中发出无助的哀嚎 “冻死宝宝了!” 这时 远处的天边出现了一 ...

  6. bzoj 4736 /uoj274【清华集训2016】温暖会指引我们前行 lct

    [清华集训2016]温暖会指引我们前行 统计 描述 提交 自定义测试 寒冬又一次肆虐了北国大地 无情的北风穿透了人们御寒的衣物 可怜虫们在冬夜中发出无助的哀嚎 “冻死宝宝了!” 这时 远处的天边出现了 ...

  7. [清华集训2016]温暖会指引我们前行——LCT+最大生成树

    题目链接: [清华集训2016]温暖会指引我们前行 题目大意:有$n$个点$m$次操作,每次操作分为三种:1.在$u,v$两点之间连接一条编号为$id$,长度为$l$,温度为$t$的边.2.查询从$u ...

  8. [BZOJ4736]温暖会指引我们前行

    BZOJ(BZOJ上的是什么鬼...) UOJ 任务描述 虽然小R住的宿舍楼早已来了暖气,但是由于某些原因,宿舍楼中的某些窗户仍然开着(例如厕所的窗户),这就使得宿舍楼中有一些路上的温度还是很低. 小 ...

  9. 【刷题】UOJ #274 【清华集训2016】温暖会指引我们前行

    寒冬又一次肆虐了北国大地 无情的北风穿透了人们御寒的衣物 可怜虫们在冬夜中发出无助的哀嚎 "冻死宝宝了!" 这时 远处的天边出现了一位火焰之神 "我将赐予你们温暖和希望! ...

随机推荐

  1. 安装android Studio和运行react native项目(基础篇)

    ANDROID_HOME环境变量 确保ANDROID_HOME环境变量正确地指向了你安装的Android SDK的路径. 打开控制面板 -> 系统和安全 -> 系统 -> 高级系统设 ...

  2. 更改eclipse(myeclipse) author的默认名字(注释的作者)

    在eclipse/myeclipse中,当添加注释的作者选项时,@author 后边一般都会默认填充的你登录计算机的用户名.如何去修改呢:第一种方法:修改计算机登录的用户名(一般不实用)第二种方法:修 ...

  3. SpringMVC spring-servlet.xml配置

    <?xml version="1.0" encoding="UTF-8"?><beans xmlns="http://www.spr ...

  4. Zabbix-Agent 客户端安装配置

    1.安装Zabbix官方的yum源 [root@crazy-acong ~]# rpm -ivh http://repo.zabbix.com/zabbix/2.2/rhel/6/x86_64/zab ...

  5. 为什么不写 @RequestParam 也能拿到参数?

    三种写法,test(String name), test(@RequestParam String name), test(@RequestParam("userName") St ...

  6. 为什么要对url进行encode

    发现现在几乎所有的网站都对url中的汉字和特殊的字符,进行了urlencode操作,也就是: http://hi.baidu.com/%BE%B2%D0%C4%C0%CF%C8%CB/creat/bl ...

  7. Android系统移植与调试之------->安装apk时出现错误Failure [INSTALL_FAILED_DEXOPT]问题解决的方法

    在android4.0源码里面编译出来apk后,用adb install (或adb install -r 重装)安装时,报错[INSTALL_FAILED_DEXOPT]. xu@xu-PC:~$ ...

  8. 又一次发现Oracle太美之awr相关脚本简介

    又一次发现Oracle太美之awr相关脚本简介 大家知道在$ORACLE_HOME/rdbms/admin下,有例如以下的相关脚本(我的环境为11.2.0.4.2): [oracle@rh64 ~]$ ...

  9. [从jQuery看JavaScript]-匿名函数与闭包(Anonymous Function and Closure)

    http://blog.csdn.net/natineprince/article/details/4759533   jQuery片段: (function(){ //这里忽略jQuery所有实现 ...

  10. linux 5-sort,uniq,tar,split

    十二.   行的排序命令sort:   1.  sort命令行选项: 选项 描述 -t 字段之间的分隔符 -f 基于字符排序时忽略大小写 -k 定义排序的域字段,或者是基于域字段的部分数据进行排序 - ...