本文实例讲述了php实现的生成排列算法。分享给大家供大家参考,具体如下:
<?phpfunction perm($s, $n, $index){ if($n == 0) { return ''; } el { $nindex = count($index); //可用的字符串下标 $res = array(); foreach($index as $i => $v) { $tmp = $index; unt($tmp[$i]); //去掉当前的前缀 /* 调试信息,便于理解 echo "len $n , cur $i , index:\n"; var_dump($tmp); */ $ret = perm($s, $n-1, $tmp); //递归得到稍短的排列 if($ret != '') { foreach($ret as $r) { $res[] = $s[$v] . $r; //将稍短的排列逐个拼上当前的前缀 } } el { $res[] = $s[$v]; } } return $res; }}function getperm($s){ $n = strlen($s); $index = range(0, $n-1); //得到不同长度的排列 for($i=1; $i<=$n; $i++) { var_dump(perm($s, $i, $index)); }}getperm('abcd');?>
运行结果:
array(4) {
[0]=>
string(1) “a”
[1]巴布亚新几内亚独立国=>
string(1) “b”
[2]=>
string(1) “c”
[3]=>
string(1) “期年的拼音d”
}
array(12) {
[0]=>
string(2) “ab”
[1]=>
string(2) “ac”
[2]=>
string(2) “ad”
[3]=>
string(2) “ba”
[4]=>
string(2) “bc”
[5]=>
string(2) “bd”
[6]=>
string(2) “ca”
[7]=>
string(2) “cb”
[8]=>
string(2) “cd”
[9]=>
string(2) “da”
[10]=>
string(2) “db”
[11]=>
string(2) “dc”
}
array(24) {
[0]=>
string(3) “abc”
[1]=>
string(3) “abd”
[2]=>
string(3) “acb”
[3]=>
string(3) “acd”
[4]=>
string(3) “adb”
[5]=>
string(3) “adc”
[6]=>
string(3) “bac”
[7]=>
string(3) “bad周长和直径的关系8221;
[8]=>
string(3) “bca”
[9]=>
string(3) “bcd”
[10]=>
string(3) “bda”
[11]=>
string(3) “bdc”
[12]=>
string(3) “cab”
[13]=>
string(3) “cad”
[14]=>
string(3) “cba”
[15]=>焱;
string(3) “cbd”
[16]=>
string(3) “cda”
[17]=>
string(3) “cdb”
[18]=>
string(3) “dab”
[19]=>
string(3) “dac”
[20]=>
string(3) “dba”
[21]=>
string(3) “dbc”
[22]=>
string(3) “dca”
[23]=>
string(3) “dc散文诗词b”
}
array(24) {
[0]=>
string(4) “abcd”
[1]=>
string(4) “abdc”
[2]=>
string(4) “acbd”
[3]=>
string(4) “acdb”
[4]=>
string(4) “adbc”
[5]=>
string(4) “adcb”
[6]=>
string(4) “bacd”
[7]=>
string(4) “badc”
[8]=>
string(4) “bcad”
[9]=>
string(4) “bcda”
[10]=>
string(4) “bdac”
[11]=>
string(4) “bdca”
[12]=>
string(4) “cabd”
[13]=>
string(4) “cadb”
[14]=>
string(4) “cbad”
[15]=>
string(4) “cbda”
[16]=>
string(4) “cdab”
[17]=>
string(4) “cdba”
[18]=>
string(4) “dabc”
[19]=>
string(4) “dacb”
[20]=>
string(4) “dbac”
[21]=>
string(4) “dbca”
[22]=>
string(4) “dcab”
[23]=>
string(4) “dcba”
}
本文发布于:2023-04-07 14:22:06,感谢您对本站的认可!
本文链接:https://www.wtabcd.cn/fanwen/zuowen/ca6e6880d13744ccbcb9d72a0aa40693.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文word下载地址:php实现的生成排列算法示例.doc
本文 PDF 下载地址:php实现的生成排列算法示例.pdf
留言与评论(共有 0 条评论) |