主頁(yè) > 知識(shí)庫(kù) > PHP實(shí)現(xiàn)字符串的全排列詳解

PHP實(shí)現(xiàn)字符串的全排列詳解

熱門標(biāo)簽:地下城堡2圖九地圖標(biāo)注 智能電話機(jī)器人排名前十名南京 七魚外呼系統(tǒng)停用嗎 阿里云400電話申請(qǐng)加工單 西區(qū)企業(yè)怎么做地圖標(biāo)注入駐 抖音有個(gè)地圖標(biāo)注是什么意思 海南人工外呼系統(tǒng)有效果嗎 保定crm外呼系統(tǒng)運(yùn)營(yíng)商 九江外呼系統(tǒng)

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

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

2.得復(fù)位以后才能再次深度優(yōu)先

3.回溯法思想

4.一張圖和一個(gè)運(yùn)行過程,只能慢慢體會(huì)了

?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();//調(diào)用入口,從索引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實(shí)現(xiàn)的簡(jiǎn)單排列組合算法應(yīng)用示例
  • php全排列遞歸算法代碼
  • 使用php計(jì)算排列組合的方法
  • 淺談PHP的排列組合(如輸入a,b,c 輸出他們的全部組合)
  • php通過排列組合實(shí)現(xiàn)1到9數(shù)字相加都等于20的方法
  • php求數(shù)組全排列,元素所有組合的方法總結(jié)
  • PHP輸出多個(gè)元素的排列或組合的方法
  • php求數(shù)組全排列,元素所有組合的方法
  • PHP實(shí)現(xiàn)基于圖的深度優(yōu)先遍歷輸出1,2,3...n的全排列功能
  • php實(shí)現(xiàn)的生成排列算法示例

標(biāo)簽:韶關(guān) 遼陽(yáng) 甘肅 涼山 十堰 梅河口 昭通 九江

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《PHP實(shí)現(xiàn)字符串的全排列詳解》,本文關(guān)鍵詞  PHP,實(shí)現(xiàn),字符串,的,全,排列,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《PHP實(shí)現(xiàn)字符串的全排列詳解》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于PHP實(shí)現(xiàn)字符串的全排列詳解的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章