首页 > 其他 > 详细

洛谷 P2652 同花顺

时间:2017-09-11 09:55:55      阅读:320      评论:0      收藏:0      [点我收藏+]

P2652 同花顺

求出已有的序列中 最长的同花顺 然后用n减去这个长度

以牌的花色为第一关键字排序,不然会wa

排序之后要判重,因为有花色和大小都一样的牌

然后 枚举每张牌,以这张牌为它以前的区间的右端点,再枚举左端点,就可以了

技术分享
 1 #include<bits/stdc++.h>
 2 using namespace std;
 3 #define maxn 1000000
 4 int n,maxx,maxl,nowl=1,cnt;
 5 struct Data{
 6     int num,x;
 7 }c[maxn],a[maxn];
 8 bool cmp(Data a,Data b) 
 9 { 
10     if(a.x==b.x) 
11     return a.num<b.num;
12     else return a.x<b.x;
13 }
14 int main()
15 {
16     scanf("%d",&n);
17     for(int i=1;i<=n;i++)
18         scanf("%d%d",&c[i].x,&c[i].num);
19     sort(c+1,c+n+1,cmp);
20     for(int i=1;i<=n;i++)
21         if(c[i-1].x!=c[i].x||c[i-1].num!=c[i].num)
22             a[++cnt]=c[i];
23     for(int i=1;i<=cnt;i++)
24     {
25         nowl=0;
26         for(int j=i;j>=1;j--)
27         {
28             if(a[i].x==a[j].x&&a[i].num-a[j].num+1<=n)    nowl++;
29             else break;
30         }
31         maxl=max(nowl,maxl);
32     }
33     printf("%d\n",n-maxl);
34     return 0;
35 }
View Code

 

洛谷 P2652 同花顺

原文:http://www.cnblogs.com/chen74123/p/7503174.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!