290
Cerința
Se dă un număr natural n
. Să se genereze, în ordine lexicografică, toate șirurile de cifre binare de lungime n
.
Date de intrare
Programul citește de la tastatură numărul n
Date de ieșire
Programul va afișa pe ecran șirurile generate, câte unul pe o linie; între elementele unui șir nu sunt spații.
Restricții și precizări
1 ≤ n ≤ 10
Exemplu
Intrare
3
Ieșire
000 001 010 011 100 101 110 111
#include <bits/stdc++.h> using namespace std; int main() { int n; cin >> n; for(int i = 0 ; i <= 1 ; ++i) { if(n==1) cout << i << endl; else for(int j = 0 ; j <= 1 ; j++) { if(n==2) cout << i << j << endl; else for(int r = 0 ; r <= 1 ; ++r) { if(n==3) cout << i << j << r <<endl; else for(int p = 0 ; p <= 1 ; ++p) { if(n==4) cout << i << j << r << p << endl; else for(int k = 0 ; k <= 1 ; ++k) { if(n==5) cout << i << j << r << p << k << endl; else for(int q = 0 ; q <= 1 ; ++q) { if(n==6) cout << i << j << r << p << k << q << endl; else for(int s = 0 ; s <= 1 ; ++s) { if(n==7) cout << i << j << r << p << k << q << s << endl; else for(int t = 0 ; t <= 1 ; ++t) { if(n==8) cout << i << j << r << p << k << q << s << t << endl; else for(int u = 0 ; u <= 1 ; ++u) { if(n==9) cout << i << j << r << p << k << q << s << t << u << endl; else for(int v = 0 ; v <= 1 ; ++v) cout << i << j << r << p << k << q << s << t << u << v << endl; } } } } } } } } } }
Comentarii