#include <cstdio>
#include <string>
void WyrazJedynkowo(unsigned liczba) {
int nawiasowania = 0;
std::string result;
if (liczba == 1) {
result.push_back('1');
} else {
while (liczba > 1) {
int aktualny_bit = liczba & 0x1;
int nastepna = liczba >> 1;
int nastepny_bit = nastepna & 0x1;
if (aktualny_bit) {
result.push_back('1');
result.push_back('+');
}
result.push_back('(');
result.push_back('1');
result.push_back('+');
result.push_back('1');
result.push_back(')');
if (nastepna > 1) {
result.push_back('*');
if (nastepny_bit) {
result.push_back('(');
nawiasowania++;
}
}
liczba >>= 1;
}
while (nawiasowania > 0) {
result.push_back(')');
nawiasowania--;
}
}
printf("%s\n", result.c_str());
}
int main() {
int liczba_testow;
scanf("%d", &liczba_testow);
for (int i=0; i<liczba_testow; i++) {
int do_wyrazenia;
scanf("%u", &do_wyrazenia);
WyrazJedynkowo(do_wyrazenia);
}
return 0;
}
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 42 43 44 45 46 47 48 49 50 51 52 53 54 55 | #include <cstdio> #include <string> void WyrazJedynkowo(unsigned liczba) { int nawiasowania = 0; std::string result; if (liczba == 1) { result.push_back('1'); } else { while (liczba > 1) { int aktualny_bit = liczba & 0x1; int nastepna = liczba >> 1; int nastepny_bit = nastepna & 0x1; if (aktualny_bit) { result.push_back('1'); result.push_back('+'); } result.push_back('('); result.push_back('1'); result.push_back('+'); result.push_back('1'); result.push_back(')'); if (nastepna > 1) { result.push_back('*'); if (nastepny_bit) { result.push_back('('); nawiasowania++; } } liczba >>= 1; } while (nawiasowania > 0) { result.push_back(')'); nawiasowania--; } } printf("%s\n", result.c_str()); } int main() { int liczba_testow; scanf("%d", &liczba_testow); for (int i=0; i<liczba_testow; i++) { int do_wyrazenia; scanf("%u", &do_wyrazenia); WyrazJedynkowo(do_wyrazenia); } return 0; } |
English