在PHP中生成任意长度的有序(加权)组合

给定按照使用普遍性排序的常用单词列表,是否可以按照“最常见”序列的顺序形成任意长度(任何所需数量的单词)的单词组合.例如,如果最常见的单词是’a,b,c’,那么对于长度为2的组合,将生成以下内容:

aa
ab
ba
bb
ac
bc
ca
cb
cc

以下是长度为3的正确列表:

aaa
aab
aba
abb
baa
bab
bba
bbb
aac
abc
bac
bbc
aca
acb
bca
bcb
acc
bcc
caa
cab
cba
cbb
cac
cbc
cca
ccb
ccc

对于任意数量的元素,这对于2或3个字(设置长度)的组合很容易实现,但是这可以用于任意长度吗?我想在PHP中实现这一点,但非常感谢伪代码甚至算法的摘要!

解决方法:

这是一个递归函数,可能是你需要的.当给出一个长度和一个字母时,这个想法是首先生成一个短的一个字母的序列,不包括那个字母.将新字母添加到末尾,您将获得涉及该字母的序列的第一部分.然后将新信件移到左侧.循环遍历每个字母序列,包括右边的新字母.

所以,如果你有gen(5,d)
它将从一开始

(aaaa)d
(aaab)d
...
(cccc)d

然后,当它完成a-c组合时,它会做

(aaa)d(a)
...
(aaa)d(d)
(aab)d(d)
... 
(ccc)d(d)

然后当它完成d作为第四个字母时它将移动到第3个字母

(aa)d(aa)

等等

<?php 
/** 
 * Word Combinations (version c) 6/22/2009 1:20:14 PM 
 * 
 * Based on pseudocode in answer provided by Erika: 
 *   https://*.com/questions/1024471/generating-ordered-weighted-combinations-of-arbitrary-length-in-php/1028356#1028356 
 *   (direct link to Erika's answer) 
 * 
 * To see the results of this script, run it: 
 *   http://stage.dustinfineout.com/*/20090622/word_combinations_c.php 
**/ 

init_generator(); 

function init_generator() { 
    global $words; 
    $words = array('a','b','c'); 
    generate_all(5);


} 

function generate_all($len){
    global $words;
    for($i = 0; $i < count($words); $i++){
        $res = generate($len, $i); 

        echo join("<br />", $res);  
        echo("<br/>");
    }   
}

function generate($len, $max_index = -1){ 
    global $words; 

    // WHEN max_index IS NEGATIVE, STARTING POSITION 
    if ($max_index < 0) { 
        $max_index = count($words) - 1; 
    } 

    $list = array(); 


    if ($len <= 0) { 
        $list[] = "";
        return $list; 
    } 

    if ($len == 1) { 

        if ($max_index >= 1) { 
            $add = generate(1, ($max_index - 1));
            foreach ($add as $addit) { 
                $list[] = $addit; 
            } 


        } 
        $list[] = $words[$max_index]; 
        return $list; 
    } 

    if($max_index == 0) { 
        $list[] = str_repeat($words[$max_index], $len); 
        return $list; 
    } 

    for ($i = 1; $i <= $len; $i++){ 
        $prefixes = generate(($len - $i), ($max_index - 1)); 
        $postfixes = generate(($i - 1), $max_index); 
        foreach ($prefixes as $pre){ 
            //print "prefix = $pre<br/>";
            foreach ($postfixes as $post){ 
                //print "postfix = $post<br/>";
                $list[] = ($pre . $words[$max_index] . $post); 
            } 
        } 
    } 
    return $list; 
} 

?>
上一篇:c# – 如何按最少到大多数非零元素的顺序迭代排列?


下一篇:c# – 使用LINQ获取不同的数字组合