「DAOI R1」Magic

「DAOI R1」Magic

题目背景

-1,-1,+2

题目描述

乔木 来到了大魔王的面前,他决定使用魔法击败魔王。

给定一个整数 nnn,表示有 nnn 个魔法阵,在每个魔法阵上都存在着一定的魔力值 aia_iai

你每次可以选择三个魔法阵 i,j,k  (i,j,ki,j,k\;(i,j,ki,j,k(i,j,k 互不相同且 ai>0a_i>0ai>0aj>0)a_j>0)aj>0),然后 乔木 将会让第 iii 个魔法阵和第 jjj 个魔法阵上的魔力值 ai,aja_i,a_jai,aj 分别减 111,并让第 kkk 个魔法阵上的魔力值 aka_kak222,我们将这称之为一次操作。

乔木 想要将所有的魔力汇聚到一起以发挥最大的威力。他想知道在经过若干次操作后,能否让其中 n−1n-1n1 个魔法阵上的魔力值为 000,并使汇聚的那一个魔法阵的魔力值为原魔法阵的所有魔力值之和。

输入格式

本题包含多组数据。

一行输入一个数 TTT,表示数据组数。

接下来对于每组数据,先输入一个正整数 nnn,然后依次输入 nnn 个整数,第 iii 个整数代表 aia_iai

输出格式

对于每组数据输出一行,若可以实现,则输出 YES,否则输出 NO

样例 #1

样例输入 #1

2
4
2 0 2 2
3
5 0 7

样例输出 #1

YES
NO

提示

样例解释

  • 对于第一组数据,可以将 a1a_1a1a3a_3a3a4a_4a4 进行两次操作。
  • 对于第二组数据,可以证明不行。

数据范围

  • 对于 5%5\%5% 的数据:1≤n≤21\le n\le21n20≤ai≤1030\le a_i\le10^30ai103
  • 对于 20%20\%20% 的数据:1≤n≤101\le n\le101n100≤ai≤1030\le a_i\le10^30ai103
  • 对于 100%100\%100% 的数据:1≤∑n≤2×1061\le \sum{n}\le2\times10^{6}1n2×1060≤ai≤1090\le a_i\le10^{9}0ai109

对于所有数据,保证 1≤T≤1001\le T\le1001T100∑i=1nai≥1\sum\limits_{i=1}^{n} a_i \ge1i=1nai1

#include<bits/stdc++.h>
#define maxn 100005
using namespace std;
int n,a[maxn];
int main() {
	int T;
	scanf("%d",&T);
	while(T--) {
		scanf("%d",&n);
		for(int i=1; i<=n; i++) scanf("%d",a+i);
		if(n==1) puts("YES");
		if(n==2) {
			if(a[1]==0 || a[2]==0) puts("YES");
			else puts("NO");
		}
		if(n==3) {
			sort(a+1,a+n+1);
			a[3]+=a[1]*2;
			a[2]-=a[1];
			a[1]=0;
			if(a[2]%3==0 || a[3]%3==0) puts("YES");
			else if((a[2]%3==1 && a[3]%3==1) || (a[3]%3==1 && a[2]%3==1)) puts("YES");
			else if((a[2]%3==2 && a[3]%3==2) || (a[3]%3==2 && a[2]%3==2)) puts("YES");
			else puts("NO");
		}
		if(n>=4) {
			int cnt0=0,cnt1=0,cnt2=0;
			for(int i=1; i<=n; i++) {
				if(a[i]==0) cnt0++;
				else if(a[i]==1) cnt1++;
				else if(a[i]==2) cnt2++;
			}
			if(cnt0==n-2 && cnt1==1 && cnt2==1) puts("NO");
			else puts("YES");
		}
	}
	getchar();
	getchar();
	return 0;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值