2012-10-01 13 views
5

posible duplicado:
generate strings with all permutation of charactergenerador de permutación recursivo para caracteres

soy principiante en C++, y realmente necesito su ayuda. Estoy haciendo un programa para permutación usando recursión. Aquí está mi código pero la salida es extraña, hay los mismos números que se repiten muchas veces y espacios. No pude averiguar cuál es el problema o quizás necesito agregar algo más. Por favor, ayúdame. Aquí está mi código:

#include <iostream> 
using namespace std; 
#define swap(x,y,t) ((t)=(x), (x)=(y), (y)=(t)) 
void perm(char *list, int i, int n); 

int main(){ 
    char a[4]={'a','b','c'}; 
    perm(a,0,3); 
    //cout<<a<<endl;  
    return 0; 
} 

void perm(char *list, int i, int n){ 
    int j, temp; 
    if (i==n){ 
     for (j=0; j<=n; j++) 
      printf("%c", list[j]); 
     printf("  "); 
    } 
    else { 
     for (j=i; j<=n; j++){ 
      swap(list[i],list[j],temp); 
      perm(list,i+1,n); 
      swap(list[i],list[j],temp); 
      cout<<list<<endl; 
     } 
    } 
} 
+0

Puede ahorrarse un montón de problemas por el simple uso de la función '' next_permutation' integrado en '. –

Respuesta

1

La función es correcta pero no la está llamando correctamente.

perm(a,0,3); 

debería ser

perm(a,0,2); 

¿Por qué?

Su bucle for:

for (j=i; j<=n; j++){ 

va hasta n, por lo n debe haber un índice válido.

Works fine

+0

muchas gracias por su respuesta ^^))) – bionian

Cuestiones relacionadas