Algorithm
Code Examples
#1 Code Example with C++ Programming
Code -
C++ Programming
#include <bits/stdc++.h>
using namespace std;
int const N = 2e5 + 1;
int n, q, a[N], fr[35], fr1[35];
bool check() {
for(int i = 0; i < 35; ++i)
if(fr1[i] != 0)
return false;
return true;
}
int main() {
scanf("%d %d", &n, &q);
for(int i = 0; i < n; ++i) {
scanf("%d", a + i);
bitset<32> bs(a[i]);
for(int i = 0; i < 32; ++i)
if(bs[i] == 1)
++fr[i];
}
while(q-- != 0) {
int tmp;
scanf("%d", &tmp>;
bitset<32> bs(tmp);
memset(fr1, 0, sizeof fr1);
for(int i = 0; i < 32; ++i)
fr1[i] = bs[i];
int cnt = 0;
for(int i = 31; i >= 0; --i) {
if(i > 0 && fr1[i] != 0 && fr[i] == 0) {
fr1[i - 1] += fr1[i] * 2;
fr1[i] = 0;
} else if(i > 0 && fr1[i] != 0 && fr[i] < fr1[i]) {
fr1[i - 1] += (fr1[i] - fr[i]) * 2;
cnt += fr[i];
fr1[i] = 0;
} else if(fr1[i] != 0 && fr[i] >= fr1[i]) {
cnt += fr1[i];
fr1[i] = 0;
}
}
if(check())
printf("%d\n", cnt);
else
puts("-1");
}
return 0;
}
Copy The Code &
Try With Live Editor
Input
5 4
2 4 8 2 4
8
5
14
10
2 4 8 2 4
8
5
14
10
Output
1
-1
3
2
-1
3
2
Demonstration
Codeforces Solution-D. Coins and Queries-Solution in C, C++, Java, Python,Coins and Queries