您的位置:首页 > 其它

文章标题Gym 100971C :triangles

2016-09-16 13:08 323 查看

triangles

Description

standard input/output

Announcement

Statements

There is a set of n segments with the lengths li. Find a segment with an integer length so that it could form a non-degenerate triangle with any two segments from the set, or tell that such segment doesn’t exist.

Input

The first line contains a single integer n(2 ≤ n ≤ 200000) — the number of segments in the set.

The second line contains n integers li separated by spaces (1 ≤ li ≤ 109) — the lengths of the segments in the set.

Output

If the required segment exists, in the first line output «YES» (without quotes). In this case in the second line output a single integer x — the length of the needed segment. If there are many such segments, output any of them.

If the required segment doesn’t exist, output «NO» (without quotes).

Sample Input

Input

2

3 4

Output

YES

2

Input

3

3 4 8

Output

YES

6

Input

3

3 4 9

Output

NO

题意:有n条边的长度,要求是否存在另外的一条边,使得与n条边中的任意两条边形成三角形,存在的话就输出YES并输出其中的一种可能,不存在就输出NO。

分析:由三角形存在定理两边之和大于第三边,两边之差小于第三边可知,我们需要求出这n条边中两边只差最大值max(|a-b|),和两边之和的最小值min(c+d);所求的x需满足max(|a-b|)< x

#include<iostream>
#include<string>
#include<cstdio>
#include<cstring>
#include<vector>
#include<math.h>
#include<map>
#include<queue>
#include<algorithm>
using namespace std;
const int inf = 0x3f3f3f3f;
int n;
long long a[200005];
int main ()
{
while (scanf ("%d",&n)!=EOF){
for (int i=0;i<n;i++){
scanf ("%lld",&a[i]);
}
sort (a,a+n);//排序
int left=a[n-1]-a[0];//找两边只差最大值
int right=a[0]+a[1];//找两边值和最小值
if (right-left>=2){
printf ("YES\n");
printf ("%d\n",left+1);
}
else printf ("NO\n");
}
return 0;
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: