#include <cstdio>
char wyr[2000];
int t, n, beg, end;
void buduj(int n) {
if (n == 1) {
wyr[beg] = '1';
return;
}
buduj(n/2);
beg--;
wyr[beg] = '(';
wyr[end + 1] = '*';
wyr[end + 2] = '(';
wyr[end + 3] = '1';
wyr[end + 4] = '+';
wyr[end + 5] = '1';
wyr[end + 6] = ')';
end = end + 7;
if (n % 2 == 1) {
wyr[end] = '+';
wyr[end + 1] = '1';
end += 2;
}
wyr[end] = ')';
return;
}
int main() {
scanf("%d", &t);
while (t--) {
beg = 40;
end = 40;
scanf("%d", &n);
buduj(n);
for (int i = beg; i <= end; i++)
printf("%c", wyr[i]);
printf("\n");
}
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 | #include <cstdio> char wyr[2000]; int t, n, beg, end; void buduj(int n) { if (n == 1) { wyr[beg] = '1'; return; } buduj(n/2); beg--; wyr[beg] = '('; wyr[end + 1] = '*'; wyr[end + 2] = '('; wyr[end + 3] = '1'; wyr[end + 4] = '+'; wyr[end + 5] = '1'; wyr[end + 6] = ')'; end = end + 7; if (n % 2 == 1) { wyr[end] = '+'; wyr[end + 1] = '1'; end += 2; } wyr[end] = ')'; return; } int main() { scanf("%d", &t); while (t--) { beg = 40; end = 40; scanf("%d", &n); buduj(n); for (int i = beg; i <= end; i++) printf("%c", wyr[i]); printf("\n"); } return 0; } |
English