婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > PHP實現字符串的全排列詳解

PHP實現字符串的全排列詳解

熱門標簽:地下城堡2圖九地圖標注 智能電話機器人排名前十名南京 七魚外呼系統停用嗎 阿里云400電話申請加工單 西區企業怎么做地圖標注入駐 抖音有個地圖標注是什么意思 海南人工外呼系統有效果嗎 保定crm外呼系統運營商 九江外呼系統

輸入一個字符串,按字典序打印出該字符串中字符的所有排列。

例如,輸入字符串abc,則打印出由字符a,b,c所能排列出來的所有字符串abc,acb,bac,bca,cab和cba。
思路:
1.利用遞歸形成遞歸樹,達到深度優先,固定首字母的效果

2.得復位以后才能再次深度優先

3.回溯法思想

4.一張圖和一個運行過程,只能慢慢體會了

?phpfunction test($str,$start,$res){    //遞歸終止條件

    if($start==strlen($str)){        $res[]=$str;        return;

    }  

    // 

    for($i=$start;$istrlen($str);++$i){        if($i==$start || $str{$i}!=$str{$start}){

            swap($str,$i,$start);var_dump($str.'==='.$start);var_dump($res);sleep(1);

            test($str,$start+1,$res);

            swap($str,$i,$start);

        }  

   

    }  

    return $res;

}function swap($str,$a,$b){    

if(!is_string($str)) return;    

$t=$str{$a};    

$str{$a}=$str{$b};    

$str{$b}=$t;

}$str="abc";$res=array();//調用入口,從索引0開始

$res=test($str,0,$res);

var_dump($res);
string(7) "abc===0"array(0) {

}string(7) "abc===1"array(0) {

}string(7) "abc===2"array(0) {

}string(7) "acb===1"array(1) {

 [0]=> string(3) "abc"}string(7) "acb===2"array(1) {

 [0]=> string(3) "abc"}string(7) "bac===0"array(2) {

 [0]=> string(3) "abc"

 [1]=> string(3) "acb"}string(7) "bac===1"array(2) {

 [0]=> string(3) "abc"

 [1]=> string(3) "acb"}string(7) "bac===2"array(2) {

 [0]=> string(3) "abc"

 [1]=> string(3) "acb"}string(7) "bca===1"array(3) {

 [0]=> string(3) "abc"

 [1]=> string(3) "acb"

 [2]=> string(3) "bac"}string(7) "bca===2"array(3) {

 [0]=> string(3) "abc"

 [1]=> string(3) "acb"

 [2]=> string(3) "bac"}string(7) "cba===0"array(4) {

 [0]=> string(3) "abc"

 [1]=> string(3) "acb"

 [2]=> string(3) "bac"

 [3]=> string(3) "bca"}string(7) "cba===1"array(4) {

 [0]=> string(3) "abc"

 [1]=> string(3) "acb"

 [2]=> string(3) "bac"

 [3]=> string(3) "bca"}string(7) "cba===2"array(4) {

 [0]=> string(3) "abc"

 [1]=> string(3) "acb"

 [2]=> string(3) "bac"

 [3]=> string(3) "bca"}string(7) "cab===1"array(5) {

 [0]=> string(3) "abc"

 [1]=> string(3) "acb"

 [2]=> string(3) "bac"

 [3]=> string(3) "bca"

 [4]=> string(3) "cba"}string(7) "cab===2"array(5) {

 [0]=> string(3) "abc"

 [1]=> string(3) "acb"

 [2]=> string(3) "bac"

 [3]=> string(3) "bca"

 [4]=> string(3) "cba"}array(6) {

 [0]=> string(3) "abc"

 [1]=> string(3) "acb"

 [2]=> string(3) "bac"

 [3]=> string(3) "bca"

 [4]=> string(3) "cba"

 [5]=> string(3) "cab"}

您可能感興趣的文章:
  • PHP實現的簡單排列組合算法應用示例
  • php全排列遞歸算法代碼
  • 使用php計算排列組合的方法
  • 淺談PHP的排列組合(如輸入a,b,c 輸出他們的全部組合)
  • php通過排列組合實現1到9數字相加都等于20的方法
  • php求數組全排列,元素所有組合的方法總結
  • PHP輸出多個元素的排列或組合的方法
  • php求數組全排列,元素所有組合的方法
  • PHP實現基于圖的深度優先遍歷輸出1,2,3...n的全排列功能
  • php實現的生成排列算法示例

標簽:韶關 遼陽 甘肅 涼山 十堰 梅河口 昭通 九江

巨人網絡通訊聲明:本文標題《PHP實現字符串的全排列詳解》,本文關鍵詞  PHP,實現,字符串,的,全,排列,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《PHP實現字符串的全排列詳解》相關的同類信息!
  • 本頁收集關于PHP實現字符串的全排列詳解的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 二连浩特市| 南木林县| 五华县| 兰西县| 元阳县| 宁国市| 桑植县| 新巴尔虎右旗| 抚州市| 原阳县| 昌黎县| 航空| 胶州市| 乐安县| 贵港市| 沽源县| 廉江市| 西丰县| 桓台县| 临颍县| 徐水县| 台东市| 长丰县| 从化市| 新化县| 乌兰浩特市| 江城| 武平县| 池州市| 六安市| 维西| 和静县| 中宁县| 商城县| 大安市| 子长县| 阿瓦提县| 新龙县| 茶陵县| 三门峡市| 屯门区|