zoukankan      html  css  js  c++  java
  • 【文文殿下】P3740 [HAOI2014]贴海报

    题解

    一开始想到离散化,然后暴力模拟。但是存在一种hack数据: [5,7] [1,5] [7,9] 这样会错误的认为第一个区间被覆盖了(因为两个端点被覆盖)。所以我们设置一个玄学调参系数,在一个区间的内部,rand几个点,属于这个区间。

    这个系数一般来讲设为5就可以了。

    代码如下:

    #include<cstdio>
    #include<algorithm>
    #include<cstdlib>
    const int maxn = 1e5+10;
    int n,m;
    int xi=5;
    int a[maxn],top;
    int rand_rang(int l,int r) {
        return (rand()%(r-l+1))+l;
    }
    int l[maxn],r[maxn];
    int vis[maxn];
    int cnt[maxn];
    
    int find(int x) {
        int pos = std::lower_bound(a+1,a+1+top,x)-a;
        return pos;
    }
    int main() {
        scanf("%d%d",&n,&m);
        for(int i = 1;i<=m;++i) {
            scanf("%d%d",l+i,r+i);
            a[++top]=l[i];a[++top]=r[i];
            for(int j = 1;j<=xi;++j) {
                a[++top]=rand_rang(l[i],r[i]);
            }
        }
        std::sort(a+1,a+1+top);
        top = std::unique(a+1,a+1+top)-a-1;
        for(int i = 1;i<=m;++i) {
            int l = find(::l[i]),r=find(::r[i]);
            for(int j = l;j<=r;++j) {
                vis[j]=i;
            }
        }
        int ans = 0;
        for(int i = 1;i<=top;++i) {
            if(cnt[vis[i]]++==0) ++ans;
        }
        printf("%d
    ",ans);
        return 0;
    }
    
  • 相关阅读:
    牛客练习赛53 A-E
    算导第二章笔记 (归并排序 之 插入排序优化)
    LightOJ 1372 (枚举 + 树状数组)
    LightOJ 1348 (树链剖分 + 线段树(树状数组))
    Light OJ 1343
    Light OJ 1266
    Light OJ 1085
    CodeForces 671C
    Codeforces Round #352 (Div. 2) (A-D)
    ZOJ1008
  • 原文地址:https://www.cnblogs.com/Syameimaru/p/10451395.html
Copyright © 2011-2022 走看看