CF #724(div2)A. Omkar and Bad Story,贪心,构造序列
Posted 小哈里
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了CF #724(div2)A. Omkar and Bad Story,贪心,构造序列相关的知识,希望对你有一定的参考价值。
problem
A. Omkar and Bad Story
time limit per test2 seconds
memory limit per test256 megabytes
inputstandard input
outputstandard output
Omkar has received a message from Anton saying “Your story for problem A is confusing. Just make a formal statement.” Because of this, Omkar gives you an array a=[a1,a2,…,an] of n distinct integers. An array b=[b1,b2,…,bk] is called nice if for any two distinct elements bi,bj of b, |bi−bj| appears in b at least once. In addition, all elements in b must be distinct. Can you add several (maybe, 0) integers to a to create a nice array b of size at most 300? If a is already nice, you don’t have to add any elements.
For example, array [3,6,9] is nice, as |6−3|=|9−6|=3, which appears in the array, and |9−3|=6, which appears in the array, while array [4,2,0,6,9] is not nice, as |9−4|=5 is not present in the array.
For integers x and y, |x−y|=x−y if x>y and |x−y|=y−x otherwise.
Input
Each test contains multiple test cases. The first line contains t (1≤t≤50), the number of test cases. Description of the test cases follows.
The first line of each test case contains a single integer n (2≤n≤100) — the length of the array a.
The second line of each test case contains n distinct integers a1,a2,⋯,an (−100≤ai≤100) — the elements of the array a.
Output
For each test case, output one line containing YES if Omkar can create a nice array b by adding elements to a and NO otherwise. The case of each letter does not matter, so yEs and nO will also be accepted.
If the first line is YES, output a second line containing a single integer k (n≤k≤300).
Then output one line containing k distinct integers b1,b2,⋯,bk (−109≤bi≤109), the elements of the nice array b. b1,b2,⋯,bk can be in any order. For each ai in a, ai must appear at least once in b.
It can be proved that if Omkar can create such an array b, then he can also do so in a way that satisfies the above constraints.
If multiple solutions exist, you can print any.
Example
inputCopy
4
3
3 0 9
2
3 4
5
-7 3 13 -2 8
4
4 8 12 6
outputCopy
yes
4
6 0 3 9
yEs
5
5 3 1 2 4
NO
Yes
6
8 12 6 2 4 10
Note
For the first case, you can add integers to a to receive the array b=[6,0,3,9]. Note that |6−3|=|9−6|=|3−0|=3 and 3 is in b, |6−0|=|9−3|=6 and 6 is in b, and |9−0|=9 is in b, so b is nice.
For the second case, you can add integers to a to receive the array b=[5,3,1,2,4]. We have that |2−1|=|3−2|=|4−3|=|5−4|=1 is in b, |3−1|=|4−2|=|5−3|=2 is in b, |4−1|=|5−2|=3 is in b, and |5−1|=4 is in b, so b is nice.
For the fourth case, you can add integers to a to receive the array b=[8,12,6,2,4,10]. We have that |4−2|=|6−4|=|8−6|=|10−8|=|12−10|=2 is in b, |6−2|=|8−4|=|10−6|=|12−8|=4 is in b, |8−2|=|10−4|=|12−6|=6 is in b, |10−2|=|12−4|=8 is in b, and |12−2|=10 is in b, so b is nice.
It can be proven that for all other test cases it is impossible to create a nice array b.
solution
#include<bits/stdc++.h>
using namespace std;
typedef long long LL;
int a[110];
int main(){
int T; cin>>T;
while(T--){
int n; cin>>n;
int mi = 1e9+10, mx = 0, ok = 1;
for(int i = 1; i <= n; i++){
int x; cin>>x;
mi = min(mi, x);
mx = max(mx, x);
if(x<0){
ok = 0;
}
}
if(ok==0){
cout<<"NO\\n";
continue;
}
cout<<"YES\\n";
cout<<mx+1<<"\\n";
for(int i = 0; i <= mx; i++){
cout<<i<<" ";
}
cout<<"\\n";
}
return 0;
}
以上是关于CF #724(div2)A. Omkar and Bad Story,贪心,构造序列的主要内容,如果未能解决你的问题,请参考以下文章
CF #738(div2)A. Mocha and Math(贪心)
E. Omkar and Forest——Codeforces Round #724 (Div. 2)
E. Omkar and Forest——Codeforces Round #724 (Div. 2)
CF #737(div2)A. Ezzat and Two Subsequences,贪心