4025: 二分图

Description

神犇有一个n个节点的图。因为神犇是神犇,所以在T时间内一些边会出现后消失。神犇要求出每一时间段内这个图是否是二分图。这么简单的问题神犇当然会做了,于是他想考考你。

Input

输入数据的第一行是三个整数n,m,T。
第2行到第m+1行,每行4个整数u,v,start,end。第i+1行的四个整数表示第i条边连接u,v两个点,这条边在start时刻出现,在第end时刻消失。

Output

输出包含T行。在第i行中,如果第i时间段内这个图是二分图,那么输出“Yes”,否则输出“No”,不含引号。

Sample Input

3 3 3
1 2 0 2
2 3 0 3
1 3 1 2

Sample Output

Yes
No
Yes

HINT

样例说明:
0时刻,出现两条边1-2和2-3。
第1时间段内,这个图是二分图,输出Yes。
1时刻,出现一条边1-3。
第2时间段内,这个图不是二分图,输出No。
2时刻,1-2和1-3两条边消失。
第3时间段内,只有一条边2-3,这个图是二分图,输出Yes。
数据范围:
n<=100000,m<=200000,T<=100000,1<=u,v<=n,0<=start<=end<=T。

Source

【分析】

  %%%大颓果,你可以看她的按秩合并题解:http://blog.csdn.net/u010336344/article/details/55194864

  我打的是最简单那种并查集,每次修改father和dis的时候把操作压入栈里面,回溯的时候恢复并查集。

  【表示第一次恢复并查集,从来没想过这个。。不过并查集时间很快的话应该也不会很耗空间吧?

  我觉得主方法更像整体二分,T给的是一个区间,像线段树一样当完全在[l,r]中的时候进行操作,其余操作分到左右两个区间里面做。

  回溯的时候恢复并查集。

  大概就是这样。

  哦对了,二分图就是看看是否有奇环,有的话一定不是二分图。

 #include<cstdio>
#include<cstdlib>
#include<cstring>
#include<iostream>
#include<algorithm>
#include<vector>
#include<stack>
using namespace std;
#define Maxn 100010 struct node {int x,y,s,t;};
vector<node > S; int fa[Maxn],dis[Maxn];
bool ans[Maxn]; struct nnode {int x,f,d;};
stack<nnode> sta; void mak_f(int x,int ff,int dd)
{
nnode tt;
tt.x=x;tt.f=fa[x];tt.d=dis[x];
sta.push(tt);
fa[x]=ff;
dis[x]=dd;
} int ffa(int x)
{
if(fa[x]!=x)
{
int ff=ffa(fa[x]);
mak_f(x,ff,(dis[fa[x]]+dis[x])%);//fa[x]=ffa(fa[x]);
}
return fa[x];
} void ffind(int l,int r,vector<node> M)
{
vector<node> ll,rr;
ll.clear();rr.clear();
int mid=(l+r)>>,now=sta.size();
bool ok=;
for(int i=;i<M.size();i++)
{
node t=M[i];
if(t.s==l&&t.t==r)
{
if(ffa(t.x)==ffa(t.y))
{
if(dis[t.x]==dis[t.y]) {ok=;break;}
}
else
{
if(ffa(t.x)!=t.x)
{
mak_f(ffa(t.x),t.x,dis[t.x]);
mak_f(t.x,t.x,);
}
mak_f(t.x,t.y,);
}
}
else if(t.t<=mid) ll.push_back(t);
else if(t.s>mid) rr.push_back(t);
else
{
node tt=t;tt.t=mid;
ll.push_back(tt);tt.s=mid+;tt.t=t.t;
rr.push_back(tt);
}
}
if(l!=r&&!ok)
{
ffind(l,mid,ll);ffind(mid+,r,rr);
}
while(sta.size()>now)
{
nnode nw=sta.top();
sta.pop();
fa[nw.x]=nw.f;dis[nw.x]=nw.d;
}
if(ok)
{
for(int i=l;i<=r;i++) ans[i]=;
}
} int main()
{
int n,m,T;
scanf("%d%d%d",&n,&m,&T);
S.clear();
for(int i=;i<=n;i++) fa[i]=i;
for(int i=;i<=n;i++) dis[i]=;
for(int i=;i<=m;i++)
{
node t;
scanf("%d%d%d%d",&t.x,&t.y,&t.s,&t.t);
t.s++;
if(t.s<=t.t) S.push_back(t);
}
for(int i=;i<=T;i++) ans[i]=;
ffind(,T,S);
for(int i=;i<=T;i++) if(ans[i]) printf("Yes\n");
else printf("No\n");
return ;
}

2017-02-16 22:07:48

【BZOJ 4025】 (CDQ?还是整体二分?+并查集及它的恢复操作)的更多相关文章

  1. [AGC002D] Stamp Rally 整体二分+并查集

    Description 给你一个n个点m个条边构成的简单无向连通图,有Q组询问,每次询问从两个点x,y走出两条路径,使这两条路径覆盖z个点,求得一种方案使得路径上经过的变的最大编号最小. Input ...

  2. BZOJ 4025 二分图(时间树+并查集)

    [题目链接] http://www.lydsy.com/JudgeOnline/problem.php?id=4025 [题目大意] 给出一张图,有些边只存在一段时间,问在一个每个时间段, 这张图是否 ...

  3. HDU 3081 Marriage Match II (网络流,最大流,二分,并查集)

    HDU 3081 Marriage Match II (网络流,最大流,二分,并查集) Description Presumably, you all have known the question ...

  4. BZOJ 4569 [Scoi2016]萌萌哒 | ST表 并查集

    传送门 BZOJ 4569 题解 ST表和并查集是我认为最优雅(其实是最好写--)的两个数据结构. 然鹅!他俩加一起的这道题,我却--没有做出来-- 咳咳. 正解是这样的: 类似ST表有\(\log ...

  5. 洛谷P2498 [SDOI2012]拯救小云公主 【二分 + 并查集】

    题目 英雄又即将踏上拯救公主的道路-- 这次的拯救目标是--爱和正义的小云公主. 英雄来到boss的洞穴门口,他一下子就懵了,因为面前不只是一只boss,而是上千只boss.当英雄意识到自己还是等级1 ...

  6. 洛谷:P1783 海滩防御(二分+并查集 最短路 最小生成树)

    题意: 给定长度为N的海滩,然后有M做防御塔,给出每座塔的位置Xi,到海岸的距离Yi. 求防御塔上最小观测半径Ri,使得海滩被封锁. 思路:要使左边界和右边界连通. 很nice,可以二分+并查集做. ...

  7. POJ2349二分+并查集,类似最小树的贪心

    题意:       给你n个点,你的任务是构建一颗通讯树,然后给你一个s表示可以选出来s个点两两通讯不花钱,就是费用是0,其他的费用就是两点的距离,有个要求就是其他的费用中最大的那个最小. 思路:   ...

  8. Cdq分治整体二分学习记录

    这点东西前前后后拖了好几个星期才学会……还是自己太菜啊. Cdq分治的思想是:把问题序列分割成左右两个,先单独处理左边,再处理左边对右边的影响,再单独处理右边.这样可以消去数据结构上的一个log,降低 ...

  9. CDQ分治&整体二分学习个人小结

    目录 小结 CDQ分治 二维LIS 第一道裸题 bzoj1176 Mokia bzoj3262 陌上花开 bzoj 1790 矩形藏宝地 hdu5126四维偏序 P3157 [CQOI2011]动态逆 ...

随机推荐

  1. 微信小程序setData子元素

    页面的数据中如果有子元素,如下图nowQuestion中的deleted元素 在小程序的setData中,不能直接用nowQuestion.deleted来设定它的值,而需要再定义一个变量承接 另外, ...

  2. html+js实现的触屏版贪吃蛇

    查看线上demo(服务器经常断开,推荐下载源码本地打开): http://47.93.103.19:8044/client/ ; 使用手机打开或者chrome浏览器的手机模式打开 源码地址 :http ...

  3. JQGrid 导出Excel 获取筛选条件

    需求描述:页面加载后,进行相关数据搜索,要求点击导出按钮后  下载Excel文件. 思路:希望在点击[导出Excel]按钮时,获取到表格搜索时的filters内容. 在百度.api.jqgrid.js ...

  4. HTML中设置超链接字体 & 字体颜色

    定义链接样式 CSS为一些特殊效果准备了特定的工具,我们称之为“伪类”.其中有几项是我们经常用到的,下面我们就详细介绍一下经常用于定义链接样式的四个伪类,它们分别是: :link :visited : ...

  5. 代码回滚:Reset、Checkout、Revert 的选择

    git reset.git checkout 和 git revert 是你的 Git 工具箱中最有用的一些命令.它们都用来撤销代码仓库中的某些更改,而前两个命令不仅可以作用于提交,还可以作用于特定文 ...

  6. Spring注解@Resource和@Autowired区别对比、spring扫描的默认bean的Id、程序获取spring容器对象

    -------------------------注解扫面的bean的ID问题-------------------------- 0.前提需要明白注解扫描出来的bean的id默认是类名首字母小写,当 ...

  7. jython

    # -*- coding: utf-8 -*- import sys import json sys.path += ["C:/Users/yangbo/Desktop/restassure ...

  8. mybaits-spring demo 记

    代码:https://github.com/bobby96333/demo_spring_batis /pom.xml <?xml version="1.0" encodin ...

  9. C json实战引擎 三 , 最后实现部分辅助函数

    引言 大学读的是一个很时髦的专业, 学了四年的游戏竞技. 可惜没学好. 但认真过, 比做什么都认真. 见证了  ...... 打的所有游戏人物中 分享一位最喜爱 的 “I've been alone ...

  10. [How to]如何通过xib来自定义UIViewController

    代码:https://github.com/xufeng79x/CreateControllerByXib 1.简介 UIViewController实例可以通过代码.storyborad或者xib方 ...