• 【uva 1617】Laptop(算法效率--贪心,2种理解)


    题意:有N条长度为1的线段,要求使每条线段分别在相应区间,且“空隙”数目最小。输出“空隙”数。(1≤N≤100000)

    解法:(P.S.我这题竟做了2个多小时,还是有点迷糊......ヽ(≧□≦)ノ)先按右端点从小到大排序,再是左端点。于是有2个理解:
    1. 扫一遍,r保存之前的线段的右端点的最大值,分情况讨论;
    2. (这个我理解了差不多1个小时......qwq 于是我好不容易理解了之后,再进行了一些小修改。)l , r 表示之前线段左、右端点的范围。再分别看没有“空隙”地加入当前线段的左、右端点的限制条件,若l+1>r,就说明这样不合法,便一定会有“空隔”。那便cnt++,并且最优化加入后当前的答案。

    注意——许多贪心题都是排序后比较相邻两个的。比如我里面写的一些“区间相关问题”—— 关于贪心算法的经典问题(算法效率 or 动态规划)

     1 #include<cstdio>
     2 #include<cstdlib>
     3 #include<cstring>
     4 #include<algorithm>
     5 using namespace std;
     6 
     7 const int N=100010;
     8 int n;
     9 struct node{int l,r;}a[N];
    10 
    11 bool cmp(node x,node y)
    12 {
    13     if (x.r!=y.r) return x.r<y.r;
    14     return x.l<y.l;
    15 }
    16 int main()
    17 {
    18     int T;
    19     scanf("%d",&T);
    20     while (T--)
    21     {
    22       scanf("%d",&n);
    23       for (int i=1;i<=n;i++) scanf("%d%d",&a[i].l,&a[i].r);
    24       sort(a+1,a+1+n,cmp);
    25       int r=a[1].r,cnt=0;
    26       for (int i=2;i<=n;i++)
    27       //r为上一个线段能处于的最靠右的位置
    28         if (r!=a[i].r)
    29         {
    30           if (r<a[i].l) cnt++,r=a[i].r;
    31           else r++;
    32         }
    33       printf("%d
    ",cnt);
    34     }
    35     return 0;
    36 }
    Code1
     1 #include<cstdio>
     2 #include<cstdlib>
     3 #include<cstring>
     4 #include<algorithm>
     5 using namespace std;
     6 
     7 const int N=100010;
     8 int n;
     9 struct node{int l,r;}a[N];
    10 
    11 int mmin(int x,int y) {return x<y?x:y;}
    12 int mmax(int x,int y) {return x>y?x:y;}
    13 bool cmp(node x,node y)
    14 {
    15     if (x.r!=y.r) return x.r<y.r;
    16     return x.l<y.l;
    17 }
    18 int main()
    19 {
    20     int T;
    21     scanf("%d",&T);
    22     while (T--)
    23     {
    24       scanf("%d",&n);
    25       for (int i=1;i<=n;i++) scanf("%d%d",&a[i].l,&a[i].r);
    26       sort(a+1,a+1+n,cmp);
    27       int l=a[1].l,r=a[1].r,cnt=0;
    28       for (int i=2;i<=n;i++)
    29       {
    30         l=mmax(l+1,a[i].l),r=mmin(r+1,a[i].r);
    31         if (l+1>r)
    32         {
    33           cnt++;
    34           l=a[i].l,r=a[i].r;
    35         }
    36       }
    37       printf("%d
    ",cnt);
    38     }
    39     return 0;
    40 }
    Code2
  • 相关阅读:
    DOM getElementById
    百度之星2014
    游艇租借
    2014年acm亚洲区域赛·鞍山站
    UVALive 4255 Guess
    UVA 10054 The Necklace
    UVA 10047 The Monocycle
    UVA 11624 Fire!
    第九届黑龙江省赛
    剑指offer系列31-----二叉树的下一个节点
  • 原文地址:https://www.cnblogs.com/konjak/p/6055836.html
Copyright © 2020-2023  润新知