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原创,但可以转载,因为我们是兄弟 爬虫能爬到这句话么哈哈哈

相关文章推荐

【POJ3657】【USACO 2008 Jan Gold】 1.Haybale Guessing 二分答案,并查集check

题意: 输入n、m表示数列长度为n,有m条有序的限制{l,r,x}。 限制:l~r间所有数最小值为x。 问到第几条限制开始出现矛盾,都不出现输出"0"。 题解: 首先这题比较厉害,正...
  • Vmurder
  • Vmurder
  • 2014年12月23日 17:46
  • 1714

poj3657 二分+并查集

二分哪一次操作是最后一次正确

POJ 1988 简单并查集,

  • 2011年03月18日 18:00
  • 2KB
  • 下载

并查集代码

  • 2015年12月12日 20:18
  • 1KB
  • 下载

poj 1182 并查集经典问题

http://poj.org/problem?id=1182 Description 动物王国中有三类动物A,B,C,这三类动物的食物链构成了有趣的环形。A吃B, B吃C,C吃A。  现有N个动物...

ACM并查集讲解的深化和扩展

  • 2016年07月01日 17:27
  • 1.58MB
  • 下载

并查集初步(黄劲松).ppt

  • 2015年04月01日 15:45
  • 424KB
  • 下载

POJ 并查集 题目汇总 ——czyuan原创

http://hi.baidu.com/czyuan_acm/item/13cbd3258c29e20d72863edf 继续数据结构的复习,本次的专题是:并查集。       并查集...

并查集.ppt

  • 2015年08月11日 20:50
  • 833KB
  • 下载

并查集的讲解

  • 2014年03月08日 19:33
  • 256KB
  • 下载
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:POJ 3657 并查集
举报原因:
原因补充:

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