用户注册



邮箱:

密码:

用户登录


邮箱:

密码:
记住登录一个月忘记密码?

发表随想


还能输入:200字
云代码 - php代码库

php 用PHP求解最长公共子串问题

2014-12-03 作者: php源代码大全举报

[php]代码库

<? php
class LCS {
    public static function main() {
        //设置字符串长度
        $substringLength1 = 20;
        $substringLength2 = 20;  //具体大小可自行设置
        $opt = array_fill(0, 21, array_fill(0, 21, null));

        // 随机生成字符串
        $x = self::GetRandomStrings($substringLength1);
        $y = self::GetRandomStrings($substringLength2);

        $startTime = microtime(true);

        // 动态规划计算所有子问题
        for ($i = $substringLength1 - 1; $i >= 0; $i--) {
            for ($j = $substringLength2 - 1; $j >= 0; $j--) {
                if ($x[$i] == $y[$j])
                    $opt[$i][$j] = $opt[$i + 1][$j + 1] + 1;
                else
                    $opt[$i][$j] = max($opt[$i + 1][$j], $opt[$i][$j + 1]);
            }
        }

        echo "substring1:".$x."\\r\\n";
        echo "substring2:".$y."\\r\\n";
        echo "LCS:";

        $i = 0;
        $j = 0;
        while ($i < $substringLength1 && $j < $substringLength2) {
            if ($x[$i] == $y[$j]) {
                echo $x[$i];
                $i++;
                $j++;
            } else if ($opt[$i + 1][$j] >= $opt[$i][$j + 1])
                $i++;
            else
                $j++;
        }

        $endTime = microtime(true);

        echo "\\r\\n";
        echo "Totle time is " . ($endTime - $startTime) . " s";
    }

    public static function GetRandomStrings($length) {
        $buffer = "abcdefghijklmnopqrstuvwxyz";
        $str = "";
        for($i = 0; $i < $length; $i++) {
            $random = rand(0, strlen($buffer) - 1);
            $str. = $buffer[$random];
        }
        return $str;
    }
}

LCS::main();
? >
//该片段来自于http://yuncode.net


网友评论    (发表评论)


发表评论:

评论须知:

  • 1、评论每次加2分,每天上限为30;
  • 2、请文明用语,共同创建干净的技术交流环境;
  • 3、若被发现提交非法信息,评论将会被删除,并且给予扣分处理,严重者给予封号处理;
  • 4、请勿发布广告信息或其他无关评论,否则将会删除评论并扣分,严重者给予封号处理。


扫码下载

加载中,请稍后...

输入口令后可复制整站源码

加载中,请稍后...