Я пытался написать программу на C, которая генерирует все возможные перестановки строки (например, 123 в коде ниже). Мне удалось, но он генерирует некоторые значения мусора после каждой возможной перестановки. Пожалуйста, помогите мне найти возможную причину. Это как-то связано с инициализацией?
Код:
#include <stdio.h>
void permute(char number[],char out[],int level,int used[]);
int main()
{
char number[] = "123";
char out[3] = "asd"; // Random initialization
int used[] = {0,0,0}; // To check if number has been used in the string output
permute(number,out,0,used);
}
void permute (char number[],char out[],int level,int used[])
{
if (level == 3)
{
printf("%s\n",out);
return;
}
int i;
for(i = 0; i < 3;i++ )
{
if( used[i] == 1) continue;
out[level] = number[i];
used[i] = 1;
permute( number, out, level + 1,used );
used[i] = 0;
}
}