Two positive integers a and b have a sum of s and a bitwise XOR of x. How many possible values are there for the ordered pair (a, b)?
Input
The first line of the input contains two integers s and x (2 ≤ s ≤ 1012, 0 ≤ x ≤ 1012), the sum and bitwise xor of the pair of positive integers, respectively.
Output
Print a single integer, the number of solutions to the given conditions. If no solutions exist, print 0.
Examples
input
9 5
output
4
input
3 3
output
2
input
5 2
output
0
Note
In the first sample, we have the following solutions: (2, 7), (3, 6), (6, 3), (7, 2).
In the second sample, the only solutions are (1, 2) and (2, 1).
Solution:
#include <bits/stdc++.h>
using namespace std;
int main() {
long long sum, x;
cin >> sum >> x;
long long a = (sum - x) / 2;
if (a < 0 || x + 2 * a != sum || (x & a) != 0) {
cout << 0 << endl;
return 0;
}
long long bits = 0;
long long tmp = x;
while (tmp > 0) {
bits += tmp & 1;
tmp >>= 1;
}
long long ans = 1LL << bits;
if (a == 0) {
ans -= 2;
}
cout << ans << endl;
return 0;
}
Related posts:
Rational Resistance
New Year and Rating
Minimum spanning tree - Kruskal with Disjoint Set Union
Jerry's Protest
Gambling Nim
Correcting Mistakes
Catalan Numbers
Lowest Common Ancestor - Farach-Colton and Bender Algorithm
Tài liệu giáo khoa chuyên Tin 3 quyển
King Escape
Design Tutorial: Learn from Life
Ordering Pizza
Zoning Restrictions
Competitive Programmer
Save the problem
The Inclusion-Exclusion Principle
Om Nom and Dark Park
Black and White Tree
Trips
Basic Geometry
Chicken or Fish?
Rectangle Puzzle
Social Network
Maximum flow - Push-relabel method improved
E-mail Addresses
Cinema
Ramesses and Corner Inversion
Little Artem
M-numbers
Digits
Hongcow Builds A Nation
Vanya and Field