#include<stdio.h>
#include<string.h>
#include<stdlib.h>
#pragma warning(disable:4996)
char result[200][200];
int count = 0;
char x[200];
int i = 0;
void add()
{
for (i = 0; i < count; i++)
{
if (strcmp(result[i], x) == 0) break;
}
if (count == 0 || count == i)
{
strcpy(result[count++], x);
}
}
void swap(char arr[], int m, int i)
{
int temp = 0;
temp = arr[m];
arr[m] = arr[i];
arr[i] = temp;
}
void pailie(char arr[], int m, int n)
{
int i;//?
if (m == n)
{
add();
}
else
{
for (i = m; i <= n; i++)
{
swap(arr, m, i);
pailie(arr, m + 1, n);
swap(arr, m, i);
}
}
}
int main()
{
gets_s(x);
pailie(x, 0, strlen(x)-1);
for (i = 0; i <count; i++)
{
printf("%s", result[i]);
}
return 0;
}
此处有问题
void pailie(char arr[], int m, int n)
{
int i;//?
你的i如果定义为全局变量,pailie会在迭代过程中重新赋值,for (i = m; i <= n; i++)这个条件会总会让你的程序陷入死循环,可以了解一下局部变量和全局变量同名时的生效范围
我明白您的意思,可是迭代时读代码一直从pailie读吗