#include <cstdio> #include <vector> using namespace std; int main() { int prime[25] = {2, 3, 5, 7, 11, 13, 17, 19, 23, 29, 31, 37, 41, 43, 47, 53, 59, 61, 67, 71, 73, 79, 83, 89, 97}; int z, suma, number; scanf("%d", &z); for(int zz=0; zz<z; zz++) { suma = 0; vector<int> syf; vector<int>::iterator s; scanf("%d", &number); if(number <= 100) { printf("1"); for(int i=2; i<number; i++) printf("+1"); printf("\n"); } else { int wynik = number; bool test = 0; int i=0; while(i<=24) { if((wynik%prime[i])==0) { syf.push_back(prime[i]); suma+=prime[i]; if(suma>100) { test = 1; break; } wynik = wynik/prime[i]; if(wynik == 1) break; } else { i++; } } if(test!=1 && wynik!=1) { for(s=syf.begin(); s != syf.end(); ++s) { printf("("); for(int j=0; j<(*s); j++) { if(j<((*s)-1)) printf("1+"); else printf("1"); } if(--syf.end()!=s) printf(")*"); else printf(")"); } printf("\n"); } else printf("NIE\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 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 | #include <cstdio> #include <vector> using namespace std; int main() { int prime[25] = {2, 3, 5, 7, 11, 13, 17, 19, 23, 29, 31, 37, 41, 43, 47, 53, 59, 61, 67, 71, 73, 79, 83, 89, 97}; int z, suma, number; scanf("%d", &z); for(int zz=0; zz<z; zz++) { suma = 0; vector<int> syf; vector<int>::iterator s; scanf("%d", &number); if(number <= 100) { printf("1"); for(int i=2; i<number; i++) printf("+1"); printf("\n"); } else { int wynik = number; bool test = 0; int i=0; while(i<=24) { if((wynik%prime[i])==0) { syf.push_back(prime[i]); suma+=prime[i]; if(suma>100) { test = 1; break; } wynik = wynik/prime[i]; if(wynik == 1) break; } else { i++; } } if(test!=1 && wynik!=1) { for(s=syf.begin(); s != syf.end(); ++s) { printf("("); for(int j=0; j<(*s); j++) { if(j<((*s)-1)) printf("1+"); else printf("1"); } if(--syf.end()!=s) printf(")*"); else printf(")"); } printf("\n"); } else printf("NIE\n"); } } return 0; } |