// Michal Orawiec
// Jedynki
#include <cstdio>
#include <string>
using namespace std;
string rozloz(int n) {
string wynik;
int count = 0;
while (n > 0) {
while (n % 2 == 0) {
wynik += "(1+1)*";
n /= 2;
}
if (n > 0) {
if (n != 1) {
wynik += "(1+";
count++;
}
else wynik += "1";
n--;
}
}
string koncoweNawiasy(count, ')');
return wynik + koncoweNawiasy;
}
int main() {
int t, n;
scanf("%d", &t);
while (t--) {
scanf("%d", &n);
printf("%s\n", rozloz(n).c_str());
}
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 | // Michal Orawiec // Jedynki #include <cstdio> #include <string> using namespace std; string rozloz(int n) { string wynik; int count = 0; while (n > 0) { while (n % 2 == 0) { wynik += "(1+1)*"; n /= 2; } if (n > 0) { if (n != 1) { wynik += "(1+"; count++; } else wynik += "1"; n--; } } string koncoweNawiasy(count, ')'); return wynik + koncoweNawiasy; } int main() { int t, n; scanf("%d", &t); while (t--) { scanf("%d", &n); printf("%s\n", rozloz(n).c_str()); } return 0; } |
English