我正在编写代码来生成数组元素的排列。我编写了两种不同类型的交换函数,一种使用临时存储可以正常工作,而另一种不使用任何临时存储则不会生成输出。为什么会这样??
以下代码工作正常
#include<iostream>
#include<cstdio>
using namespace std;
int tt=0;
void swap1 (int v[], int i, int j) {
int t;
t = v[i];
v[i] = v[j];
v[j] = t;
}
void permute(int arr[],int n,int index)
{
if(index==n)
{
for(int i=0;i<n;i++) printf ("%c", arr[i]) ;
printf("\n");
tt++;
}
else
for(int j=index; j < n ;j++)
{
swap1(arr,index,j);
permute(arr,n,index+1);
swap1(arr,j,index);
}
}
int main()
{
int arr[]={'a','b','c','d'};
permute(arr,4,0);
cout<<endl;
printf("%d\n",tt);
getchar();
}
output:
acbd
acdb
adcb
adbc
bacd
badc
bcad
bcda
bdca
bdac
cbad
cbda
cabd
cadb
cdab
cdba
dbca
dbac
dcba
dcab
dacb
dabc
24
虽然以下代码不输出排列:
#include<iostream>
#include<cstdio>
using namespace std;
int tt=0;
void swap(int v[],int i,int j)
{
v[i]= v[i] + v[j];
v[j]= v[i] - v[j];
v[i]= v[i] - v[j];
}
void permute(int arr[],int n,int index)
{
if(index==n)
{
for(int i=0;i<n;i++) printf ("%c", arr[i]) ;
printf("\n");
tt++;
}
else
for(int j=index; j < n ;j++)
{
swap(arr,index,j);
permute(arr,n,index+1);
swap(arr,j,index);
}
}
int main()
{
int arr[]={'a','b','c','d'};
permute(arr,4,0);
cout<<endl;
printf("%d\n",tt);
getchar();
}
output:
24