zzuli oj 1146 吃糖果

Description

  HOHO,终于从Speakless手上赢走了所有的糖果,是Gardon吃糖果时有个特殊的癖好,就是不喜欢连续两次吃一样的糖果,喜欢先吃一颗A种类的糖果,下一次换一种 口味,吃一颗B种类的糖果,这样;可是Gardon不知道是否存在一种吃糖果的顺序使得他能把所有糖果都吃完?请你写个程序帮忙计算一下。 

Input

  第一行有一个整数T,接下来T组数据,每组数据占2行,第一行是一个整数N(0 < N <= 1000000),表示糖果的种类。第二行是N个数,表示每种糖果的数目Mi(0 < Mi <= 1000000)。

Output

  对于每组数据,输出一行,包含一个"Yes"或者"No"。

Sample Input

  2
  3
  4 1 1
  5
  5 4 3 2 1

Sample Output

  No
  Yes

 这道题中比较重要的是数量最多的那种糖果,因为不管吃哪一种糖果,接着都可以吃数量最多的那种,所以把其他所有糖果的总数加起来,和数量最多的那种比较,如果max和sum的差大于1时,就不能按要求吃完所有糖果了。

 

 1 #include <iostream>
 2 using namespace std;
 3 int kinds[1000010]; 
 4 int main(int argc, char** argv)
 5 {
 6     int t,n;
 7     int i,j;
 8     scanf("%d",&t);
 9     while(t--)
10     {
11         int max=0;
12         scanf("%d",&n);
13         for(i=0;i<n;i++)
14         {
15             scanf("%d",&kinds[i]);
16             if(max<kinds[i])
17                 max=kinds[i];
18         }
19         long long sum=0;
20         for(i=0;i<n;i++)
21         {
22             if(kinds[i]<max)
23                 sum+=kinds[i];
24         }
25         
26         if(max-1>sum)
27             printf("No\n");
28         else
29             printf("Yes\n");
30     }
31     return 0;
32 }

 

转载于:https://www.cnblogs.com/millerchan/p/5071407.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值