传送门

A. Bear and Three Balls
time limit per test

2 seconds

memory limit per test

256 megabytes

input

standard input

output

standard output

Limak is a little polar bear. He has n balls, the i-th
ball has size ti.

Limak wants to give one ball to each of his three friends. Giving gifts isn't easy — there are two rules Limak must obey to make friends happy:

  • No two friends can get balls of the same size.
  • No two friends can get balls of sizes that differ by more than 2.

For example, Limak can choose balls with sizes 4, 5 and 3,
or balls with sizes 90, 91 and 92.
But he can't choose balls with sizes 5, 5and 6 (two
friends would get balls of the same size), and he can't choose balls with sizes 30, 31 and 33 (because
sizes 30 and 33 differ by more than 2).

Your task is to check whether Limak can choose three balls that satisfy conditions above.

Input

The first line of the input contains one integer n (3 ≤ n ≤ 50) —
the number of balls Limak has.

The second line contains n integers t1, t2, ..., tn (1 ≤ ti ≤ 1000)
where ti denotes the size
of the i-th ball.

Output

Print "YES" (without quotes) if Limak can choose three balls of distinct sizes, such that any two of them differ by no more than 2.
Otherwise, print "NO" (without quotes).

Examples
input
  1. 4
  2. 18 55 16 17
output
  1. YES
input
  1. 6
  2. 40 41 43 44 44 44
output
  1. NO
input
  1. 8
  2. 5 972 3 4 1 4 970 971
output
  1. YES
题目大意:
就是给定 n 个数。让你求的就是是否存在三个连续的数。


解题思路:

这个题本来这么简单不想写的,可是突然发现一个函数还是比較不错的,unique(),就是这个函数,本来我是打算暴力的后来一寻思太麻烦了。就用集合写的。写到一半突然发现迭代器 it 不能加2。所以炸了,后来就用一个数组存的每个*it 的数,有点小麻烦,详细看我第一个代码
My First AC Code:
  1. <span style="font-size:18px;">#include <iostream>
  2. #include <algorithm>
  3. #include <set>
  4. #include <cstdio>
  5. #include <cstring>
  6. using namespace std;
  7. set <int> s;
  8. set <int> ::iterator it;
  9. int a[105];
  10. int main()
  11. {
  12. int n, x;
  13. while(cin>>n)
  14. {
  15. for(int i=0; i<n; i++)
  16. {
  17. cin>>x;
  18. s.insert(x);
  19. }
  20. memset(a, 0, sizeof(a));
  21. int cnt = 0;
  22. for(it=s.begin(); it!=s.end(); it++)
  23. a[cnt++] = *it;///每一个都存一遍 实在是没招了 set学的不好呀。
  24.  
  25.  

  26. bool ok = 0;
  27. for(int i=1; i<cnt; i++)
  28. {
  29. if(a[i]==a[i-1]+1 && a[i]+1==a[i+1])
  30. {
  31. ok = 1;
  32. break;
  33. }
  34. }
  35. if(ok)
  36. puts("YES");
  37. else
  38. puts("NO");
  39. }
  40. return 0;
  41. }</span>

接下来我要说的就是这篇博客的重点了(有没有想到高中老师呀...)介绍一个 STL 算法,unique(),这个函数是用来去重的,这还是我一队友告诉我的呢,我感觉自己好low啊,我具体的说一下:

unique的功能是去除相邻的反复元素(仅仅保留一个),事实上它并非真正意思上的把反复的元素删除,仅仅是把反复的元素移到后面去了,然后还是保存到了原数组中,然后
返回去重后最后一个元素的地址,由于unique去除的是相邻的反复元素。所以一般用之前都会要排一下序。
int tmp = unique(a,a+n)-a;我们仅仅须要写上这么一句话。即可了,别忘了最后还得减a由于这个函数返回的就是地址,所以要减去,而tmp这个变量里存的就是去重之后的数组的长度。还是比較不错的吧,上我第二个代码:
My Second AC Code:

  1. <span style="font-size:18px;">#include <iostream>
  2. #include <algorithm>
  3. #include <cstdio>
  4. using namespace std;
  5.  
  6. int a[105];
  7. int main()
  8. {
  9. int n, x;
  10. while(cin>>n)
  11. {
  12. for(int i=0; i<n; i++)
  13. cin>>a[i];
  14. sort(a,a+n);
  15. int tmp = unique(a,a+n)-a;///头文件 <algorithm>,还是挺好的,去重用的
  16. bool ok = 0;
  17. for(int i=1; i<tmp; i++)
  18. {
  19. if(a[i]==a[i-1]+1 && a[i]+1==a[i+1])
  20. {
  21. ok = 1;
  22. break;
  23. }
  24. }
  25. if(ok)
  26. puts("YES");
  27. else
  28. puts("NO");
  29. }
  30. return 0;
  31. }
  32. </span>

CodeForces 653 A. Bear and Three Balls——(IndiaHacks 2016 - Online Edition (Div. 1 + Div. 2))的更多相关文章

  1. 【codeforces】Bear and Three Balls(排序,去重)

    Bear and Three Balls Time Limit:2000MS     Memory Limit:262144KB     64bit IO Format:%I64d & %I6 ...

  2. codeforces 653A A. Bear and Three Balls(水题)

    题目链接: A. Bear and Three Balls time limit per test 2 seconds memory limit per test 256 megabytes inpu ...

  3. IndiaHacks 2016 - Online Edition (Div. 1 + Div. 2)——A - Bear and Three Balls(unique函数的使用)

    A. Bear and Three Balls time limit per test 2 seconds memory limit per test 256 megabytes input stan ...

  4. IndiaHacks 2016 - Online Edition (Div. 1 + Div. 2) A. Bear and Three Balls 水题

    A. Bear and Three Balls 题目连接: http://www.codeforces.com/contest/653/problem/A Description Limak is a ...

  5. CodeForces - 660F:Bear and Bowling 4(DP+斜率优化)

    Limak is an old brown bear. He often goes bowling with his friends. Today he feels really good and t ...

  6. Codeforces 750E - New Year and Old Subsequence(线段树维护矩阵乘法,板子题)

    Codeforces 题目传送门 & 洛谷题目传送门 u1s1 我做这道 *2600 的动力是 wjz 出了道这个套路的题,而我连起码的思路都没有,wtcl/kk 首先考虑怎样对某个固定的串计 ...

  7. CodeForces - 896D :Nephren Runs a Cinema(卡特兰数&组合数学---比较综合的一道题)

    Lakhesh loves to make movies, so Nephren helps her run a cinema. We may call it No. 68 Cinema. Howev ...

  8. Codeforces 1304F2 Animal Observation (hard version) 代码(dp滑动窗口线段树区间更新优化)

    https://codeforces.com/contest/1304/problem/F2 #include<bits/stdc++.h> using namespace std; ; ...

  9. IndiaHacks 2016 - Online Edition (Div. 1 + Div. 2) E. Bear and Forgotten Tree 2 bfs set 反图的生成树

    E. Bear and Forgotten Tree 2 题目连接: http://www.codeforces.com/contest/653/problem/E Description A tre ...

随机推荐

  1. mybatis中打印sql语句

    在mybatis-config.xml中properties节点下,配置一个settings节点 <settings> <setting name="cacheEnable ...

  2. pd_ds 之 hash

    http://attack.cf/?post=23 打个广告....

  3. Java中常用的操作PDF的类库

    iText iText是一个能够快速产生PDF文件的java类库.iText的java类对于那些要产生包含文本,表格,图形的只读文档是很有用的.它的类库尤其与java Servlet有很好的给合.使用 ...

  4. viewpager无线轮播获取网络图片

    首先创建小圆点 小圆点的两个属性一共两个属性另一个跟这个一个样,只不过颜色能让我们区分的 <?xml version="1.0" encoding="utf-8&q ...

  5. illumina测序原理

    一些常用基本概念的介绍: flowcell流动池 是指Illumina测序时,测序反应发生的位置,1个flowcell含有8条lane lane通道 每一个flowcell上都有8条泳道,用于测序反应 ...

  6. Python 之动态添加属性以及方法

    import types class Person(object): def __init__(self, newName, newAge): self.name = newName self.age ...

  7. C#---EF映射MySQL

    使用EF CodeFirst连接MySql数据库 如何使用EF CodeFirst连接MySql数据库? 我们这篇文章介绍怎么使用EF连接MySql 作者的环境 VS2017.Win10.MySql5 ...

  8. PHP 数据库连接 (Mysql Mysqli PDO)

    1.PHP与Mysql扩展(本扩展自 PHP 5.5.0 起已废弃,并在将来会被移除),PHP原生的方式去连接数据库,是面向过程的 <?php $mysql_conf = array( 'hos ...

  9. 思维风暴 codeforces (1060A) Phone Numbers

    这个题我真是我的问题,我看到这种题直接就想着怎么用string去枚举破解,开了一个数组去做结果模拟失败,可能开个stl容器能做的好一点...但是这个题完全不是这样做的...实际上直接比较8的个数和合法 ...

  10. LOJ 6145 Easy (动态点分治+线段树)

    题目传送门 先建出来点分树,以每个点为根开线段树,维护点分子树内编号为$[l,r]$的儿子到根的距离最小值 每次查询$x$开始,沿着点分树向上跑,在每个点的线段树的$[l,r]$区间里都查一遍取$mi ...