-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathP10036.cpp
41 lines (38 loc) · 828 Bytes
/
P10036.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
#include <iostream>
#include <cstdio>
#include <cstring>
int main() {
int M, N, K, a[10000];
int possible[100];
scanf("%d", &M);
for(int cas = 0; cas < M; ++cas) {
// Read input:
scanf("%d %d", &N, &K);
long sum = 0;
for(int i = 0; i < N; ++i) {
scanf("%d", &a[i]);
if(a[i] < 0)
a[i] = -a[i];
sum += a[i];
}
sum %= K;
memset(possible, 0, K*sizeof(int));
possible[sum] = 1;
for(int i = 0; i < N; ++i) {
// find all divisible:
int add = 2*K*a[i]-2*a[i];
for(int j = 0; j < K; ++j) {
int j2 = (j+add)%K;
if(possible[j] > 0 && possible[j] <= i+1 && possible[j2] == 0)
possible[j2] = i+2;
}
if(possible[0] != 0)
break;
}
if(possible[0] != 0)
puts("Divisible");
else
puts("Not divisible");
}
return 0;
}