Cod sursa(job #2557693)
| Utilizator | Data | 25 februarie 2020 22:31:24 | |
|---|---|---|---|
| Problema | Submultimi | Scor | 0 |
| Compilator | cpp-64 | Status | done |
| Runda | Arhiva educationala | Marime | 0.59 kb |
#include <bits/stdc++.h>
using namespace std;
ifstream fin("bfs.in");
ofstream fout("bfs.out");
const int MAXN = 1 * 1e5 + 5;
int n, v[MAXN], p;
void afis(int k){
for(int i = 1; i <= k; ++i)
fout << v[i] << " ";
fout << '\n';
}
bool ok(int k){
for(int i = 1; i < k; ++i)
if(v[i] == v[k]) return false;
return true;
}
void backtr(int k){
for(int i = v[k - 1] + 1; i <= n; ++i){
v[k] = i;
if(ok(k)){
afis(k);
backtr(k + 1);
}
}
}
int main()
{
fin >> n;
backtr(1);
return 0;
}
