我有这段代码,我打算对输出进行排序,但是
#include <iostream>
#include <string.h>
using namespace std;
/* Prototipo de función */
void Permutaciones(char *, int l=0);
char *cadena[200];
int m=0;
int main() {
char palabra[13];
cin>>palabra;
Permutaciones(palabra);
cout<<cadena[18];
return 0;
}
void Permutaciones(char * cad, int l) {
char c; /* variable auxiliar para intercambio */
int i, j; /* variables para bucles */
int n = strlen(cad);
for(i = 0; i < n-l; i++) {
if(n-l > 2){
Permutaciones(cad, l+1);
}
else {
cadena[m]=cad;
cout<<m<<endl;
m++;
}
/* Intercambio de posiciones */
c = cad[l];
cad[l] = cad[l+i+1];
cad[l+i+1] = c;
if(l+i == n-1) {
for(j = l; j < n; j++){
cad[j] = cad[j+1];
}
cad[n] = 0;
}
}
}
我打算创建一个全局字符数组(cadena),但不起作用。
例如用户写 bca 然后程序打印:
bca
bac
cba
cab
abc
acb
但我需要对程序打印进行排序,例如:
abc
acb
bac
bca
cab
cba
请你帮助我好吗?
我不知道我怎么能做到。