C语言递归问题(全排列)
voidperm(char*list,inti,intn){intj,temp;if(i==n){for(j=0;j<=n;j++)printf("%c",list[j]...
void perm (char*list,int i,int n)
{intj,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);
prem(list,i+1,n);
swap(list[i],list[j],temp);
}
}
}
程序是怎么递归调用的,如果list={A,B,C}
这个程序能输出排列的全排列的几种情况吗,(其中swap函数已定义,为交换list【i】与list【j】的值)
为什么其中i没有初值,假设i的初值为0,第一次完成调用后i的值应该为3,输出应该是ABC,下面i的值还会继续增加,i>3,就不会在进行递归,其他的排列不是输不出来了吗? 展开
{intj,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);
prem(list,i+1,n);
swap(list[i],list[j],temp);
}
}
}
程序是怎么递归调用的,如果list={A,B,C}
这个程序能输出排列的全排列的几种情况吗,(其中swap函数已定义,为交换list【i】与list【j】的值)
为什么其中i没有初值,假设i的初值为0,第一次完成调用后i的值应该为3,输出应该是ABC,下面i的值还会继续增加,i>3,就不会在进行递归,其他的排列不是输不出来了吗? 展开
3个回答
展开全部
#include <stdio.h>
void swap(char &a,char &b,char c)
{
c=a; a=b; b=c;
}
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);
}
}
}
void main()
{
char list[3]={'A','B','C'};
perm(list,0,2);
}
void swap(char &a,char &b,char c)
{
c=a; a=b; b=c;
}
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);
}
}
}
void main()
{
char list[3]={'A','B','C'};
perm(list,0,2);
}
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
可以输出所有的排列,i和n表示排列的起始点和终止点比如说要排列"abcd"起点就是0,终点是3,perm(“abcd”,0,3)就可以了。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
引用zhangyafei3020的回答:
#include <stdio.h>
void swap(char &a,char &b,char c)
{
c=a; a=b; b=c;
}
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);
}
}
}
void main()
{
char list[3]={'A','B','C'};
perm(list,0,2);
}
#include <stdio.h>
void swap(char &a,char &b,char c)
{
c=a; a=b; b=c;
}
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);
}
}
}
void main()
{
char list[3]={'A','B','C'};
perm(list,0,2);
}
展开全部
最后是
int main(void)
int main(void)
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询