php全排列递归算法代码

 更新时间:2012年10月09日 19:40:45   作者:  
php全排列递归算法代码,需要的朋友可以参考下
算法原理

如果用P表示n个元素的全排列,而Pi表示n个元素中不包含元素i的全排列,(i)Pi表示在排列Pi前面加上前缀i的排列,那么n个元素的全排列可递归定义为:
    ① 如果n=1,则排列P只有一个元素i;
    ② 如果n>1,则全排列P由排列(i)Pi构成;
根据定义,可以看出如果已经生成(k-1)个元素的排列Pi,那么k个元素的排列可以在每个Pi前面加上元素i而生成。
代码实现
复制代码 代码如下:

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');

不过,经多次测试运行结果,发现存在一个问题:若是存在相同的元素,则全排列有重复。
例如'122'的全排列只有三种情况:'122'、'212'、'221';上面方法却有重复。
略修改,加个判断重复的标志,解决了问题(代码如下):
复制代码 代码如下:

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>';

相关文章

  • mysql5的sql文件导入到mysql4的方法

    mysql5的sql文件导入到mysql4的方法

    有时候用到将高版本的数据库转移到低版本的数据库中,下面是mysql5数据转到mysql4的方法
    2008-10-10
  • php array_flip() 删除数组重复元素

    php array_flip() 删除数组重复元素

    在PHP中,用于删除数组中重复元素有一个可用的函数,那就是 array_unique(), 但是它并不是一个最高效的方法,使用array_flip() 函数将比array_uniqure()在速度上高出五倍左右。
    2009-01-01
  • php中fsockopen用法实例

    php中fsockopen用法实例

    这篇文章主要介绍了php中fsockopen用法,实例分析了fsockopen的创建、写入及关闭等具体流程,需要的朋友可以参考下
    2015-01-01
  • 深入理解PHP之OpCode原理详解

    深入理解PHP之OpCode原理详解

    这篇文章主要介绍了深入理解PHP之OpCode原理,较为详细的分析了php程序的相关编译机制与运行原理,需要的朋友可以参考下
    2016-06-06
  • PHP实现的基于单向链表解决约瑟夫环问题示例

    PHP实现的基于单向链表解决约瑟夫环问题示例

    这篇文章主要介绍了PHP实现的基于单向链表解决约瑟夫环问题,结合具体实例形式分析了php使用单链表解决约瑟夫环问题的算法原理与相关操作技巧,需要的朋友可以参考下
    2017-09-09
  • php+pdo实现的购物车类完整示例

    php+pdo实现的购物车类完整示例

    这篇文章主要介绍了php+pdo实现的购物车类,结合完整实例形式分析了PHP结合pdo操作数据库读写实现购物车功能相关实现与使用方法,需要的朋友可以参考下
    2020-01-01
  • php中trim函数实例用法

    php中trim函数实例用法

    在本篇文章里小编给大家整理的是一篇关于php中trim函数实例用法内容,有兴趣的朋友们可以学习下。
    2021-01-01
  • php中判断一个字符串包含另一个字符串的方法

    php中判断一个字符串包含另一个字符串的方法

    这篇文章主要为大家分享一下一个字符串包含另一个字符串的方法,主要使用了strpos或数组的方法实现
    2007-03-03
  • php全角字符转换为半角函数

    php全角字符转换为半角函数

    这篇文章主要介绍了PHP全角半角转换函数,把目前能找到的所有全角都列出来了一个个替换吧,需要的朋友可以参考下
    2014-02-02
  • Sorting Array Values in PHP(数组排序)

    Sorting Array Values in PHP(数组排序)

    有时候,你可能需要对数组内的值进行排序,那么就可以参考下面的文章。
    2011-09-09

最新评论