Scrieți un program care citeşte o valoare naturală impară pentru n
şi apoi generează şi afişează în ordine crescătoare lexicografic toate combinaţiile formate din n
litere mici care îndeplinesc următoarele proprietăţi:
– încep şi se termină cu a
;
– oricare două litere alăturate dintr-o combinaţie sunt consecutive în alfabet.
Astfel, pentru n=5
, combinaţiile afişate sunt, în ordine, următoarele: ababa, abcba
.
Date de intrare
Programul citește de la tastatură numărul n
, impar.
Date de ieșire
Programul va afișa pe ecran, pe rânduri separate, combinaţiile care îndeplinesc proprietăţile cerute.
Restricții și precizări
3 ≤ n ≤ 25
Exemplu
Intrare
5
Ieșire
ababa abcba
#include <iostream> using namespace std; int n,X[52]; char L[]="abcdefghijklmnopqrstuvwxyz"; int modul(int n) { if(n<0) n=-n; return n; } void afisare() { for(int i=1;i<=n;i++) cout<<L[X[i]]; cout<<'\n'; } void back(int k) { for(int i=X[k-1]-1;i<=X[k-1]+1;i=i+2) if(i>=0) { X[k]=i; if(k==n) { if(X[n]==0) afisare(); } else back(k+1); } } int main() { cin>>n; X[1]=0; back(2); return 0; }