PHP字符串全排列算法

Posted xiami2046

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了PHP字符串全排列算法相关的知识,希望对你有一定的参考价值。

<?php
/**
 * PHP字符串全排列算法
 */
$results = [];
$arr = [];

function bfs($start) {
    global $arr;
    global $results;

    $queue = [];
    array_push($queue, $start);

    while( !empty($queue) ) {
        $cur = array_shift($queue);
        if(strlen($cur) === count($arr)) {
            array_push($results, $cur);
        }

        $arr_temp = $arr;
        for ($i=0; $i<strlen($cur); $i++) {
            unset($arr_temp[$cur[$i]]);
        }

        foreach ($arr_temp as $key => $value) {
            $node = $cur . $key;
            array_push($queue, $node);
        }
    }
}

function allPermutation($string) {
    $array = [];
    for($i=0; $i<strlen($string); $i++) {
        array_push($array, $string[$i]);
    }
    sort($array);

    foreach ($array as $item) {
        global $arr;
        $arr[$item] = 1;
    }

    foreach ($array as $item) {
        bfs($item);
    }
}

allPermutation(‘abcde‘);
var_dump($results);

以上是关于PHP字符串全排列算法的主要内容,如果未能解决你的问题,请参考以下文章

算法——全排列

PHP实现全排列(递归算法)

算法习题---字符串的全排序列

codeup1959: 全排列 及全排列算法详解

c语言全排列

字符串去反复全排列算法