forked from sureshmangs/Code
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy path1536A - Omkar and Bad Story.cpp
105 lines (70 loc) · 3.22 KB
/
1536A - Omkar and Bad Story.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
/*
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.
*/
#include<bits/stdc++.h>
using namespace std;
void solve() {
int n;
cin >> n;
vector <int> v(n);
for (auto &x: v) cin >> x;
int mini = *min_element(v.begin(), v.end());
int maxi = *max_element(v.begin(), v.end());
if (mini < 0) {
cout << "NO\n";
return;
}
cout << "YES\n";
cout << maxi + 1 << "\n";
for (int i = 0; i <= maxi; i++) cout << i << " ";
cout << "\n";
}
int main(){
ios_base::sync_with_stdio(false);
cin.tie(NULL);
int t = 1;
cin >> t;
while (t--) {
solve();
}
return 0;
}