문제
링크
풀이
#include <iostream>
using namespace std;
using int128 = __int128;
int128 power(int128 a, int128 b) {
int128 ret = 1;
while (b) {
if (b & 1) ret *= a;
a *= a;
b >>= 1;
}
return ret;
}
void print(int128 n) {
if (n == 0) return;
print(n / 10);
cout << (char)(n % 10 + '0');
}
bool solve(void) {
unsigned long long n; cin >> n; n--;
if (n == -1) return false;
cout << "{";
bool first = true;
for (int i=0; i<64; i++) {
if (n & (1ULL << i)) {
if (!first) cout << ",";
first = false;
cout << " ";
print(power(3, i));
}
}
cout << " }\n";
return true;
}
int main(void) {
ios::sync_with_stdio(false);
cin.tie(nullptr);
while (solve());
return 0;
}