-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathSplittingNumbers.cpp
More file actions
40 lines (40 loc) · 878 Bytes
/
SplittingNumbers.cpp
File metadata and controls
40 lines (40 loc) · 878 Bytes
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
#include <bits/stdc++.h>
using namespace std;
#define FastIO ios_base::sync_with_stdio(0); cin.tie(0); cout.tie(0)
#define sz(a) int((a).size())
#define sza(a) (int)(sizeof(a)/sizeof((a)[0]))
#define all(c) (c).begin(),(c).end()
#define rep(i,a,n) for (int i=(a);i<(n);i++)
#define clr(x) memset(x,0,sizeof x)
#define ft first
#define sd second
typedef vector<int> vi;
typedef unsigned long long ll;
typedef unsigned long ul;
const int MX = 10e5 + 1;
void Solution() {
unsigned int x;
while (cin >> x, x) {
unsigned int a = 0, b = 0, i = 1;
bool turn = true;
while (x) {
if (x & 1) {
a += turn ? i : 0;
b += !turn ? i : 0;
turn = !turn;
}
x /= 2;
i *= 2;
}
cout << a << " " << b << endl;
}
}
int main() {
FastIO;
#ifndef ONLINE_JUDGE
freopen("input.in", "r", stdin);
// freopen("output.txt", "w", stdout);
#endif
Solution();
return 0;
}