0

我正在寻找可以生成以下内容的 PHP 想法/代码/算法:

我有 5 个字符字符串 [a-zA-Z0-9]

我想用可变过滤器生成排列

筛选 :

  1. 字符串是“W”
  2. 字符串是一个数字
  3. 字符串是“T”
  4. 字符串是大写的
  5. 字符串是“3”

编辑:

<?php

$reset = fopen('list.txt', 'w');
fclose($reset);

$chars = str_split("abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789");

$file = fopen('list.txt', 'a+');

foreach ($chars as $c0) {
    foreach ($chars as $c1) {
        foreach ($chars as $c2) {
            foreach ($chars as $c3) {
                foreach ($chars as $c4) {

                    $filter = "/[a-z][a-z][a-z][a-z][A-Z]/";
                    $list = $c0 . $c1 . $c2 . $c3 . $c4;

                    if (preg_match($filter, $list)) {
                        $data = $list . "\n";
                        file_put_contents('list.txt', $data, FILE_APPEND);
                    } 
                }
            }
        }
    }
}
fclose($file);
?>
4

2 回答 2

1

对于 php,你可以下载这个包: http: //pear.php.net/package/Math_Combinatorics

于 2012-08-18T20:23:38.803 回答
0

与其生成所有可能的排列然后对其进行过滤,不如创建返回字符串中每个字符的可能值的生成器。这会更有效(仅静态 W 将允许您将输入大小缩小一个非常大的因子)。

您可以通过将函数包装在一个简单的类中来创建生成器(以允许您保持内部状态),为每次迭代返回每个可能的标记。然后,您通过组合对每个生成器的调用并创建可能的返回值来创建排列。

我还强烈建议您不要将 file_get_contents 和 file_put_contents 用于此类事情。使用 打开文件fopen,然后在fwrite()每次有新排列时执行。fclose生成所有排列后调用。

于 2012-08-18T19:07:47.700 回答