【day1】同花顺
来源:互联网 发布:澳洲4g网络制式 编辑:程序博客网 时间:2024/06/10 02:38
题目描述
所谓同花顺,就是指一些扑克牌,它们花色相同,并且数字连续。 现在我手里有 n 张扑克牌,但它们可能并不能凑成同花顺。我现在想知道,最 少更换其中的多少张牌,我能让这 n 张牌都凑成同花顺?
输入格式
第一行一个整数 n,表示扑克牌的张数。 接下来 n 行,每行两个整数 ai 和 bi。其中 ai 表示第 i 张牌的花色,bi 表示第 i 张牌的数字。
输出格式 一行一个整数,表示最少更换多少张牌可以达到目标。
样例输入 1
5
1 1
1 2
1 3
1 4
1 5
样例输出 1
0
数据范围
对于 30% 的数据,n ≤ 10。 对于 60% 的数据,n ≤ 105,1 ≤ ai ≤ 105,1 ≤ bi ≤ n。 对于 100% 的数据,n ≤ 105,1 ≤ ai,bi ≤ 109。
按题意搜一下就行了。重点是先去重,用unique函数,不是真的删除而是把重复元素放到最后,返回第一个被去重元素的地址,如1,1,2,2,3去重后1,2,3,1,2返回位置3。结构体里重载运算符记一下。
#include<iostream>#include<cstdlib>#include<cstdio>#include<cmath>#include<cstring>#include<algorithm>#include<iomanip>using namespace std;int n,orin,num,ans;struct data{ int a,b; bool operator<(const data &o) const{ return a<o.a||a==o.a&&b<o.b; } bool operator == (const data &o) const{ return a == o.a && b == o.b; }};data c[100005];bool cmp(data x,data y){ if(x.a<y.a)return 1; if(x.a==y.a&&x.b<y.b)return 1; return 0;}int main(){ freopen("card.in","r",stdin); freopen("card.out","w",stdout); scanf("%d",&n); for(int i=1;i<=n;i++) scanf("%d%d",&c[i].a,&c[i].b); sort(c+1,c+n+1); orin=n; n=unique(c+1,c+n+1)-(c+1); for(int i=1;i<=n;i++) { num=0; for(int j=i+1;j<=n;j++) if(c[i].a==c[j].a&&c[j].b-c[i].b+1<=orin) num++; else break;//少了这句TLE ans=max(ans,num); } cout<<orin-ans-1<<endl; return 0;}
阅读全文
0 0
- 【day1】同花顺
- SDSC 2017 Day1 T2 && 洛谷 2652 同花顺
- 同花顺
- 同花顺
- 2017日照夏令营 day1 t2 洛谷P2652 同花顺
- 同花顺使用说明
- 同花顺 tzc
- 同花顺面试
- 同花顺小游戏
- B 同花顺
- Day1
- day1
- day1
- day1
- day1
- day1
- day1
- Day1
- Spring Cloud入门教程(番外篇一):RestTemplate使用指南
- Linux多线程,锁的相关问题
- 类型转换和io流
- 1012. 数字分类 (20)
- 干货1:头结点链表
- 【day1】同花顺
- Python-ElasticSearch搜索
- 设计模式C++实现(4)——单例模式
- 使用VS2013编译开源的飞行控制器APM代码
- MVC4中使用React.js入门
- 412. Fizz Buzz
- Mac下配置Sdk platform-tools目录的环境变量
- html javascript 函数(二)
- 排序--1