「DAOI R1」Magic

「DAOI R1」Magic

题目背景

-1,-1,+2

题目描述

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

给定一个整数 n n n,表示有 n n n 个魔法阵,在每个魔法阵上都存在着一定的魔力值 a i a_i ai

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

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

输入格式

本题包含多组数据。

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

接下来对于每组数据,先输入一个正整数 n n n,然后依次输入 n n n 个整数,第 i i i 个整数代表 a i a_i ai

输出格式

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

样例 #1

样例输入 #1

2
4
2 0 2 2
3
5 0 7

样例输出 #1

YES
NO

提示

样例解释

  • 对于第一组数据,可以将 a 1 a_1 a1 a 3 a_3 a3 a 4 a_4 a4 进行两次操作。
  • 对于第二组数据,可以证明不行。

数据范围

  • 对于 5 % 5\% 5% 的数据: 1 ≤ n ≤ 2 1\le n\le2 1n2 0 ≤ a i ≤ 1 0 3 0\le a_i\le10^3 0ai103
  • 对于 20 % 20\% 20% 的数据: 1 ≤ n ≤ 10 1\le n\le10 1n10 0 ≤ a i ≤ 1 0 3 0\le a_i\le10^3 0ai103
  • 对于 100 % 100\% 100% 的数据: 1 ≤ ∑ n ≤ 2 × 1 0 6 1\le \sum{n}\le2\times10^{6} 1n2×106 0 ≤ a i ≤ 1 0 9 0\le a_i\le10^{9} 0ai109

对于所有数据,保证 1 ≤ T ≤ 100 1\le T\le100 1T100 ∑ i = 1 n a i ≥ 1 \sum\limits_{i=1}^{n} a_i \ge1 i=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;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.xdnf.cn/news/143027.html

如若内容造成侵权/违法违规/事实不符,请联系一条长河网进行投诉反馈,一经查实,立即删除!

相关文章

RTMP协议在无人机巡检中的应用场景

为什么要用无人机巡检 好多开发者对无人机巡检技术方案&#xff0c;相对陌生&#xff0c;实际上&#xff0c;无人机巡检就是利用无人机对特定区域或设施进行定期或不定期的检查。这种巡检方式相比传统的人工巡检具有显著的优势&#xff0c;包括速度快、覆盖广、风险低、准确性…

出厂非澎湃OS手机解BL锁

脚本作者&#xff1a;酷安mlgmxyysd 脚本项目链接&#xff1a;https://github.com/MlgmXyysd/Xiaomi-HyperOS-BootLoader-Bypass/ 参考 B站作者&#xff1a;蓝空穹 https://www.bilibili.com/read/cv33210124/ 其他参考&#xff1a;云墨清风、水墨青竹、Magisk中文网 决定解BL…

【每日刷题】Day124

【每日刷题】Day124 &#x1f955;个人主页&#xff1a;开敲&#x1f349; &#x1f525;所属专栏&#xff1a;每日刷题&#x1f34d; &#x1f33c;文章目录&#x1f33c; 1. LCR 079. 子集 - 力扣&#xff08;LeetCode&#xff09; 2. 1863. 找出所有子集的异或总和再求和 …

滑动窗口(6)_找到字符串中所有字母异位词

个人主页&#xff1a;C忠实粉丝 欢迎 点赞&#x1f44d; 收藏✨ 留言✉ 加关注&#x1f493;本文由 C忠实粉丝 原创 滑动窗口(6)_找到字符串中所有字母异位词 收录于专栏【经典算法练习】 本专栏旨在分享学习算法的一点学习笔记&#xff0c;欢迎大家在评论区交流讨论&#x1f4…

Jetbrains开发工具使用通义灵码

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 前言一、安装二、使用步骤1.模型选择2.存在的问题 总结 前言 之前用过tabnine等AI工具&#xff0c;tabnine还行&#xff0c;有免费版&#xff0c;但是效果有限&…

element-ui 日期选择器设置禁用日期

element-ui 日期选择器设置禁用日期 效果图如下&#xff1a; 2024-09-01 到2024-09-18之间的日期都不可选 2024-01-01之前的日期都不可选 官方文档中 picker-options 相关的介绍 实现功能&#xff1a; ​ 某仓库有限制最大可放置资产数量&#xff0c;且资产出借和存放都有…

编码实现:求整数存储在内中的二进制中1的个数

//编码实现&#xff1a;求整数存储在内中的二进制中1的个数 #include<stdio.h> int ejz(unsigned int n) {int count 0;while (n){if (n % 2 1)count;n n / 2;}return count; } int main() {int num 0;printf("请输入一个整数&#xff1a;");scanf("%…

一站式费用管理系统 破解企业财务困局

在企业的运营过程中&#xff0c;财务管理常常面临着复杂多样的挑战。尤其是在处理案件的应收应付、内部提成以及合作方分成等事务时&#xff0c;其复杂性让财务人员倍感压力。这些财务环节相互交织&#xff0c;每一个环节都可能存在数据统计不准确、流程繁琐等问题。启服云费用…

Python绘图时【坐标轴文字相互重叠/覆盖】问题的解决方法【matplotlib】

Python绘图时【坐标轴文字相互重叠/覆盖】问题的解决方法 有时候我们使用python程序的matplotlib包&#xff0c;生成一些柱状图或折线图&#xff0c;会出现坐标文字放不下&#xff0c;相互覆盖的问题。&#xff08;比如用下面的代码生成的图片&#xff09; import matplotlib…

Python 从入门到实战21(面向对象简介)

我们的目标是&#xff1a;通过这一套资料学习下来&#xff0c;通过熟练掌握python基础&#xff0c;然后结合经典实例、实践相结合&#xff0c;使我们完全掌握python&#xff0c;并做到独立完成项目开发的能力。 上篇文章我们讨论了函数的相关知识。今天我们将学习一下面向对象…

微服务配置中心介绍

在微服务架构中&#xff0c;配置中心是一个非常重要的组件&#xff0c;它负责管理所有服务的配置信息&#xff0c;使得配置管理变得更加集中和动态。配置中心能够极大地提高微服务架构的灵活性和可维护性。 为什么需要配置中心&#xff1f; 在传统的单体应用中&#xff0c;配置…

视觉Transformer(ViT) :全面超越CNN,看懂这篇文章就没什么能难倒你了!

【视觉Transformer】(Vision Transformer, ViT) 是一种革命性的技术&#xff0c;它将Transformer架构应用于视觉识别任务&#xff0c;通过自注意力机制来捕捉图像中的特征关系&#xff0c;显著增强了模型对视觉信息的解析力。这一领域的研究不仅打破了传统卷积神经网络&#xf…

KDD 2024论文分享┆STAMP:一种基于时空图神经网络的微服务工作负载预测方法

论文分享简介 本推文详细介绍了一篇最新论文成果《Integrating System State into Spatio Temporal Graph Neural Network for Microservice Workload Prediction》&#xff0c;论文的作者包括&#xff1a;上海交通大学先进网络实验室: 罗旸、高墨涵、余哲梦&#xff0c;高晓沨…

AI编程的特点及SCSAI平台在AI编程方面的一些思路

团长团 AI智造AI编程 2024年09月18日 18:25 北京 说先来看看AI编程的优缺点&#xff0c;然后我们再看看SCSAI在AI编程方面的一些可能选择 使用AI编程的优点 ‌AI编程的优点包括提升编程效率、降低编程门槛、优化程序结构、加强软件可靠性、促进跨领域融合&#xff0c;而缺点则…

supermap iclient3d for cesium中的平移,旋转

昨天写的模型机头不是速度的方向 基础知识 屏幕坐标系&#xff0c;笛卡尔空间直角坐标系&#xff0c;大地坐标系 平移和旋转都是基于笛卡尔空间直角坐标系&#xff0c;也就是基于地心。但是我们想实现模型的旋转是基于模型的局部坐标系&#xff0c;那么就要坐标转换。 向量归…

秒懂C++之特殊类设计

目录 设计一个类&#xff0c;不能被拷贝 设计一个类&#xff0c;只能在堆上创建对象 设计一个类&#xff0c;只能在栈上创建对象 设计一个类&#xff0c;无法被继承 设计一个类&#xff0c;只能创建一个对象(单例模式) 饿汉模式 懒汉模式 设计一个类&#xff0c;不能被拷…

从数据仓库到数据中台再到数据飞轮:我了解的数据技术进化史

这里写目录标题 前言数据仓库&#xff1a;数据整合的起点数据中台&#xff1a;数据共享的桥梁数据飞轮&#xff1a;业务与数据的双向驱动结语 前言 在当今这个数据驱动的时代&#xff0c;企业发展离不开对数据的深度挖掘和高效利用。从最初的数据仓库&#xff0c;到后来的数据…

字节跳动冯佳时:大语言模型在计算机视觉领域的应用、问题和我们的解法

演讲嘉宾&#xff5c;冯佳时 编辑 &#xff5c;蔡芳芳 近年来&#xff0c;大语言模型 (LLMs) 在文本理解与生成领域取得了显著进展。然而&#xff0c;LLMs 在理解和生成自然信号&#xff08;例如图像&#xff0c;视频&#xff09;等&#xff0c;还处在比较早期的探索阶段。为…

单例模式(饿汉式-懒汉式)

我给面试官讲解了单例模式后&#xff0c;他对我竖起了大拇指&#xff01;https://blog.csdn.net/weixin_41949328/article/details/107296517?ops_request_misc%257B%2522request%255Fid%2522%253A%2522FAEE9ABD-432D-416C-98C6-9DD939138DEB%2522%252C%2522scm%2522%253A%252…

HTML中的文字/分区标记/特殊符号

1.font标记&#xff1a;用来设置文字的字体&#xff0c;大小&#xff0c;颜色&#xff0c;等属性 <!--font:font标记用来设置字体大小颜色属性size:设置字号&#xff0c;默认是3号&#xff0c;1表示4号&#xff0c;-1表示2号&#xff0c;取值范围是[1,7]或[-7,-1]color:设置…