色尼玛亚洲综合影院,亚洲3atv精品一区二区三区,麻豆freexxxx性91精品,欧美在线91

php全排列遞歸算法代碼

算法原理

如果用P表示n個(gè)元素的全排列,而Pi表示n個(gè)元素中不包含元素i的全排列,(i)Pi表示在排列Pi前面加上前綴i的排列,那么n個(gè)元素的全排列可遞歸定義為:
    ① 如果n=1,則排列P只有一個(gè)元素i;
    ② 如果n>1,則全排列P由排列(i)Pi構(gòu)成;
根據(jù)定義,可以看出如果已經(jīng)生成(k-1)個(gè)元素的排列Pi,那么k個(gè)元素的排列可以在每個(gè)Pi前面加上元素i而生成。
代碼實(shí)現(xiàn)
復(fù)制代碼 代碼如下:
function rank($base, $temp=null)
{
    $len = strlen($base);
    if($len <= 1)
    {
        echo $temp.$base.'<br/>';
    }
    else
    {
        for($i=0; $i< $len; ++$i)
        {
            rank(substr($base, 0, $i).substr($base, $i+1, $len-$i-1), $temp.$base[$i]);
        }
    }
}
rank('123');

不過,經(jīng)多次測試運(yùn)行結(jié)果,發(fā)現(xiàn)存在一個(gè)問題:若是存在相同的元素,則全排列有重復(fù)。
例如'122'的全排列只有三種情況:'122'、'212'、'221';上面方法卻有重復(fù)。
略修改,加個(gè)判斷重復(fù)的標(biāo)志,解決了問題(代碼如下):
復(fù)制代碼 代碼如下:
function fsRank($base, $temp=null)
{
    static $ret = array();
    $len = strlen($base);
    if($len <= 1)
    {
        //echo $temp.$base.'<br/>';
        $ret[] = $temp.$base;
    }
    else
    {
        for($i=0; $i< $len; ++$i)
        {
            $had_flag = false;
            for($j=0; $j<$i; ++$j)
            {
                if($base[$i] == $base[$j])
                {
                    $had_flag = true;
                    break;
                }
            }
            if($had_flag)
            {
                continue;
            }
            fsRank(substr($base, 0, $i).substr($base, $i+1, $len-$i-1), $temp.$base[$i]);
        }
    }
    return $ret;
}
print '<pre>';
print_r(fsRank('122'));
print '</pre>';

php技術(shù)php全排列遞歸算法代碼,轉(zhuǎn)載需保留來源!

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請第一時(shí)間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 平顺县| 怀宁县| 白银市| 射阳县| 崇明县| 丽水市| 高阳县| 洛宁县| 万山特区| 鸡东县| 丹棱县| 安溪县| 县级市| 渭南市| 株洲市| 富裕县| 政和县| 东辽县| 柳州市| 霍林郭勒市| 平邑县| 上思县| 高雄县| 九龙县| 凤冈县| 城市| 西平县| 广安市| 丰原市| 陆川县| 安塞县| 临海市| 荆门市| 闽侯县| 宁南县| 雅江县| 新晃| 武邑县| 南岸区| 阳山县| 扬州市|