POJ 3657 并查集

原创 2016年08月30日 11:20:54

题意:
这里写图片描述
这里写图片描述

思路:

1.二分+线段树(但是会TLE 本地测没有任何问题,但是POJ上就是会挂……)
2.二分+并查集

我搞了一下午+一晚上才搞出来…………..(多半时间是在查错)

首先 如果我们想知道这头奶牛之前的奶牛回答的是不是错的怎么办呢?

把回答的A从大到小排个序。这里有几种错的方式:

  1. 如果后面的区间完全被前面的区间包含,这是错的
  2. 如果有两个不相交的区间的A是一样的,这也是错的(题目保证没有两堆干草的数量是一样的)

注意取相同A的区间的时候不要超过当前二分的mid

并查集的使用也很关键……
如果是第一次覆盖 每回暴力修改一个区间
随后就可以跳着修改了…..

(有很多很多小技巧 感谢NEIGHTHORN的帮助 (和队长的代码))

//By SiriusRen
#include <cstdio>
#include <algorithm>
using namespace std;
int n,q,ans=0,f[1111111];
struct Section{int from,to,minn;}sec[25555],cpy[25555];
bool cmp(Section a,Section b){return a.minn>b.minn;}
int find(int x){return x==f[x]?x:f[x]=find(f[x]);}
inline bool check(int pos){
    for(int i=1;i<=n;i++)f[i]=i;
    for(int i=1;i<=pos;i++)cpy[i]=sec[i];
    sort(cpy+1,cpy+1+pos,cmp);
    for(int i=1,j;i<=pos;i=j+1){
        int x=cpy[i].from,y=cpy[i].to,X=x,Y=y;
        j=i;
        while(cpy[j].minn==cpy[j+1].minn&&j+1<=pos){
            j++;
            x=max(x,cpy[j].from),X=min(X,cpy[j].from);
            y=min(y,cpy[j].to),Y=max(Y,cpy[j].to);
        }
        if(y<x||find(y)<x)return 0;
        while(X<=Y)
            if(find(Y)==Y)f[Y]=find(X-1),Y--;
            else Y=find(Y);
    }
    return 1;
}
int main(){
    scanf("%d%d",&n,&q);
    for(int i=1;i<=q;i++)
        scanf("%d%d%d",&sec[i].from,&sec[i].to,&sec[i].minn);
    int l=1,r=q;
    while(l<=r){
        int mid=(l+r)>>1;
        if(check(mid))l=mid+1;
        else r=mid-1,ans=mid;
    }
    printf("%d\n",ans);
}

这里写图片描述

版权声明:本文由SiriusRen原创,未经允许不得转载

POJ并查集的题目汇总

POJ1611 The suspects题目描述: 有很多组学生,在同一个组的学生经常会接触,也会有新的同学的加入。但是SARS是很容易传染的,只要在改组有一位同学感染SARS,那么该组的所有同...
  • u013244517
  • u013244517
  • 2015年01月13日 17:20
  • 323

POJ并查集小结(转)

并查集小结 并查集大体分为三个:普通的并查集,带种类的并查集,扩展的并查集(主要是必须指定合并时的父子关系,或者统计一些数据,比如此集合内的元素数目。) POJ-1182 经典的种类并查...
  • shahdza
  • shahdza
  • 2011年07月06日 09:04
  • 6238

食物链 POJ1182 -- 并查集

食物链 Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 26553   Accepted:...
  • tiantangrenjian
  • tiantangrenjian
  • 2011年12月19日 21:06
  • 9285

【带偏移量的并查集】:poj***,Butterfly

输入 输入包含多组数据,以文件结束符为终止。 每组数据第一行为两个整数,分别是n和m: n为蝴蝶的数量,编号从0到n-1 m为关系的数量 接下来是m组关系数据,每组数据占一行,为三个整数,前两个整...
  • mmc2015
  • mmc2015
  • 2015年12月02日 22:07
  • 886

poj Supermarket(贪心)(并查集)(优先队列)

Supermarket Description A supermarket has a set Prod of products on sale. It earns a profit px fo...
  • blessLZH0108
  • blessLZH0108
  • 2017年03月08日 21:48
  • 294

poj 1182 食物链(经典!种类并查集)

链接: http://poj.org/problem?id=1182 原题: Description 动物王国中有三类动物A,B,C,这三类动物的食物链构成了有趣的环形...
  • shuangde800
  • shuangde800
  • 2012年09月24日 00:10
  • 7340

POJ - 2912 Rochambeau 种类并查集

题意:有三组小朋友在玩石头剪刀布,同一组的小朋友出的手势是一样的。这些小朋友中有一个是裁判,他可以随便出手势。现在给定一些小朋友的关系,问能否判断出裁判,如果能最早什么时候能够找到裁判。      ...
  • flyawayl
  • flyawayl
  • 2017年04月03日 11:02
  • 335

poj 3728(LCA+并查集应用)

The merchant Time Limit: 3000MS   Memory Limit: 65536K Total Submissions: 1520   A...
  • fp_hzq
  • fp_hzq
  • 2011年09月14日 21:40
  • 1615

poj 3728(LCA+并查集+DP)

思路理解,但是代码实现不行,其中是并查集更新他复杂了,,,另外,可以用RMQ来搞。代码是修改别人的代码的。 转: 题意:给出一棵节点有值的树,给出Q个询问(...
  • Weiguang_123
  • Weiguang_123
  • 2012年07月06日 10:38
  • 1751

POJ 2912 Rochambeau(枚举+并查集)

转载请注明出处,谢谢http://blog.csdn.net/acm_cxlove/article/details/7854526       by---cxlove  题目:给出n个人玩剪刀石...
  • ACM_cxlove
  • ACM_cxlove
  • 2012年10月20日 19:33
  • 2631
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:POJ 3657 并查集
举报原因:
原因补充:

(最多只允许输入30个字)