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
#include <cstdio>
#include <vector>
#include <cassert>

std::vector<int> v;

int main() {
	int T;
	
	scanf("%d", &T);
	
	while (T--) {
		int n;
		scanf("%d", &n);
		v.clear();
		
		while (n>0) {
			if (n%2==0)
				v.push_back(0);
			else
				v.push_back(1);
			
			n/=2;
		}
		
		for (int i=0; i<v.size()-1; i++)
			printf("(");
		
		assert(v.back()==1);
		
		printf("1");
		v.pop_back();
		
		while (!v.empty()) {
			printf("*(1+1)");
			
			if (v.back()==1)
				printf("+1");
			
			printf(")");
			
			v.pop_back();
		}
		
		printf("\n");
	}
	
	return 0;
}
// ADG