353
Cerința
Se citește o mulțime cu n numere naturale. Afișați în ordine lexicografică toate permutările mulțimii citite în care elementul minim și cel maxim nu își schimbă poziția.
Date de intrare
Programul citește de la tastatură numărul n, iar apoi n numere naturale distincte, separate prin spații.
Date de ieșire
Programul va afișa pe ecran permutările cerute, pe rânduri separate, fiecare permutare având elementele separate prin câte un spațiu.
Restricții și precizări
1 ≤ n ≤ 10- cele
nnumere citite vor fi mai mici decât1.000.000.000și vor fi distincte
Exemplu
Intrare
6 8 2 7 9 4 5
Ieșire
4 2 5 9 7 8 4 2 5 9 8 7 4 2 7 9 5 8 4 2 7 9 8 5 4 2 8 9 5 7 ... 8 2 5 9 7 4 8 2 7 9 4 5 8 2 7 9 5 4
Explicație
În exemplu se generează 24 de permutări în care numerele 2 și 9 nu își schimbă pozițiile.
#include <bits/stdc++.h>
using namespace std;
int n , a[11] , x[11] , p[11] , indm , indM , mini = 999999999 , maxi , c[11] , cnt;
int afisare()
{
int pp = 1;
for(int i = 1 ; i <= n ; i++)
if(i == indm || i == indM) cout << a[i] << " ";
else cout << c[x[pp]] << " " , pp++;
cout << '\n';
}
void back(int k)
{
for(int i = 1 ; i <= cnt ; i++)
if(!p[i])
{
x[k] = i;
p[i] = 1;
if(k == cnt) afisare();
else back(k + 1);
p[i] = 0;
}
}
int main()
{
cin >> n;
for(int i = 1 ; i <= n ; i++)
cin >> a[i];
for(int i = 1 ; i <= n ; i++)
{
if(a[i] < mini) mini = a[i] , indm = i;
if(a[i] > maxi) maxi = a[i] , indM = i;
}
for(int i = 1 ; i <= n ; i++)
if(i != indm && i != indM) c[++cnt] = a[i];
sort(c + 1 , c + cnt + 1);
back(1);
}
Comentarii