php求数组全排列,元素所有组合的方法。分享给大家供大家参考,具体如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
|
<?php $source = array ( 'pll' , '我' , '爱' , '你' , '嘿' ); sort( $source ); //保证初始数组是有序的 $last = count ( $source ) - 1; //$source尾部元素下标 $x = $last ; $count = 1; //组合个数统计 echo implode( ',' , $source ), "<br>" ; //输出第一种组合 while (true) { $y = $x --; //相邻的两个元素 if ( $source [ $x ] < $source [ $y ]) { //如果前一个元素的值小于后一个元素的值 $z = $last ; while ( $source [ $x ] > $source [ $z ]) { //从尾部开始,找到第一个大于 $x 元素的值 $z --; } /* 交换 $x 和 $z 元素的值 */ list( $source [ $x ], $source [ $z ]) = array ( $source [ $z ], $source [ $x ]); /* 将 $y 之后的元素全部逆向排列 */ for ( $i = $last ; $i > $y ; $i --, $y ++) { list( $source [ $i ], $source [ $y ]) = array ( $source [ $y ], $source [ $i ]); } echo implode( ',' , $source ), "<br>" ; //输出组合 $x = $last ; $count ++; } if ( $x == 0) { //全部组合完毕 break ; } } echo 'Total: ' , $count , "n" ; ?> |
© 版权声明
本文刊载的所有内容,包括文字、图片、音频、视频、软件、程序、以及网页版式设计等部门来源于互联网,版权均归原作者所有!本网站提供的内容服务于个人学习、研究或欣赏,以及其他非商业性或非盈利性用途,但同时应遵守著作权法及其他相关法律的规定,不得侵犯本网站及相关权利人的合法权利。
联系信息:邮箱aoxolcom@163.com或见网站底部。
联系信息:邮箱aoxolcom@163.com或见网站底部。
THE END
请登录后发表评论
注册
社交帐号登录