ZKX's LAB

全排列的算法 求c语言全排列算法

2020-11-26知识12

一个C语言全排列的算法。 比如,输入3,则将123的全排列全部输出:123,132,213,231 includemain(){int a1,a2,a3,a4,a5,a6,a7,a8,a9,n,t=0;scanf(\"%d\",&n);for(a1=1;a1;a1+)if(n=1){printf(\"%d\\n\",a1);t=t+1;}elsefor(a2=1;a2;a2+)if(a2。a1){if(n=2){printf(\"%d%d\\n\",a1,a2);t=t+1;}elsefor(a3=1;a3;a3+)if(a3。a2&a3。a1){if(n=3){printf(\"%d%d%d\\n\",a1,a2,a3);t=t+1;}elsefor(a4=1;a4;a4+)if(a4。a3&a4。a2&a4。a1){if(n=4){printf(\"%d%d%d%d\\n\",a1,a2,a3,a4);t=t+1;}elsefor(a5=1;a5;a5+)if(a5。a4&a5。a3&a5。a2&a5。a1){if(n=5){printf(\"%d%d%d%d%d\\n\",a1,a2,a3,a4,a5);t=t+1;}elsefor(a6=1;a6;a6+)if(a6。a5&a6。a4&a6。a3&a6。a2&a6。a1){if(n=6){printf(\"%d%d%d%d%d%d\\n\",a1,a2,a3,a4,a5,a6);t=t+1;}elsefor(a7=1;a7;a7+)if(a7。a6&a7。a5&a7。a4&a7。a3&a7。a2&a7。a1){if(n=7){printf(\"%d%d%d%d%d%d%d\\n\",a1,a2,a3,a4,a5,a6,a7);t=t+1;}elsefor(a8=1;a8;a8+)if(a8。a7&a8。a6&a8。a5&a8。a4&a8。a3&a8。a2&a8。a1){if(n=8){printf(\"%d%d%d%d%d%d%d%d\\n\",a1,a2,a3,a4,a5,a6,a7,a8);t=t+1;}elsefor(a9=1;a9;a9+)if(a9。a8&a9。a7&a9。a6&a9。a5&a9。a4&a9。a3&a9。a2&a9。a1){if(n=9){printf(\"%d%d%d%d%d%d%d%d%d\\n\",a1,a2,a3,a4,a5,a6,a7,a8,a9);t=t+。

全排列的算法 求c语言全排列算法

求c语言全排列算法 这个说起来太麻烦了,我找了一个,你看看行不,不可以的话,私聊吧.全排列用的是 置换算法,算法这东西重在理解。具体代码并不那么重要。全排列是将一组数按一定顺序进行排列,如果这组数有n个,那么全排列数为n。个。现以{1,2,3,4,5}为例说明如何编写全排列的递归算法。1、首先看最后两个数4,5。它们的全排列为4 5和5 4,即以4开头的5的全排列和以5开头的4的全排列。由于一个数的全排列就是其本身,从而得到以上结果。2、再看后三个数3,4,5。它们的全排列为3 4 5、3 5 4、4 3 5、4 5 3、5 3 4、5 4 3 六组数。即以3开头的和4,5的全排列的组合、以4开头的和3,5的全排列的组合和以5开头的和3,4的全排列的组合.从而可以推断,设一组数p={r1,r2,r3,.,rn},全排列为perm(p),pn=p-{rn}。因此perm(p)=r1perm(p1),r2perm(p2),r3perm(p3),.,rnperm(pn)。当n=1时perm(p}=r1。为了更容易理解,将整组数中的所有的数分别与第一个数交换,这样就总是在处理后n-1个数的全排列。算法如下:includeint n=0;void swap(int*a,int*b){int m;m=*a;a=*b;b=m;}void perm(int list[],int k,int m){int i;if(k>;m){for(i=0;i;i+)printf(\"%d\",list[i]);printf(\"\\n\");n+;}else{for(i。

全排列的算法 求c语言全排列算法

求c语言全排列算法 这个说起来太麻烦了,我找了一个,你看看行不,不可以的话,私聊吧.全排列用的是 置换算法,算法这东西重在理解。具体代码并不那么重要。全排列是将一组数按一定顺序进行排列,。

全排列的算法 求c语言全排列算法

随机阅读

qrcode
访问手机版