PHP 最长公共子序列LCS 中文汉字版本怎么写?

 bls6653474 发布于 2022-12-01 10:39

已经写了ASCII字母版

function LCS($str_1, $str_2) {
  $len_1 = strlen($str_1);
  $len_2 = strlen($str_2);
  $len = $len_1 > $len_2 ? $len_1 : $len_2;

  $dp = array();
  for ($i = 0; $i <= $len; $i++) {
    $dp[$i] = array();
    $dp[$i][0] = 0;
    $dp[0][$i] = 0;
  }

  for ($i = 1; $i <= $len_1; $i++) {
    for ($j = 1; $j <= $len_2; $j++) {
      if ($str_1[$i - 1] == $str_2[$j - 1]) {
        $dp[$i][$j] = $dp[$i - 1][$j - 1] + 1;
      } else {
        $dp[$i][$j] = $dp[$i - 1][$j] > $dp[$i][$j - 1] ? $dp[$i - 1][$j] : $dp[$i][$j - 1];
      }
    }
  }

  return $dp[$len_1][$len_2];
}

如何扩展成中文版?

1 个回答
  • 我自己解决了,只能自问自答了

    <?php
    //最长公共子序列英文版
    function LCS_en($str_1, $str_2) {
      $len_1 = strlen($str_1);
      $len_2 = strlen($str_2);
      $len = $len_1 > $len_2 ? $len_1 : $len_2;
    
      $dp = array();
      for ($i = 0; $i <= $len; $i++) {
        $dp[$i] = array();
        $dp[$i][0] = 0;
        $dp[0][$i] = 0;
      }
    
      for ($i = 1; $i <= $len_1; $i++) {
        for ($j = 1; $j <= $len_2; $j++) {
          if ($str_1[$i - 1] == $str_2[$j - 1]) {
            $dp[$i][$j] = $dp[$i - 1][$j - 1] + 1;
          } else {
            $dp[$i][$j] = $dp[$i - 1][$j] > $dp[$i][$j - 1] ? $dp[$i - 1][$j] : $dp[$i][$j - 1];
          }
        }
      }
    
      return $dp[$len_1][$len_2];
    }
    
    //拆分字符串
    function mbStringToArray($string, $encoding = 'UTF-8') {
      $arrayResult = array();
    
      while ($iLen = mb_strlen($string, $encoding)) {
        array_push($arrayResult, mb_substr($string, 0, 1, $encoding));
        $string = mb_substr($string, 1, $iLen, $encoding);
      }
    
      return $arrayResult;
    }
    
    //最长公共子序列中文版
    function LCS_cn($str1, $str2, $encoding = 'UTF-8') {
      $mb_len1 = mb_strlen($str1, $encoding);
      $mb_len2 = mb_strlen($str2, $encoding);
    
      $mb_str1 = mbStringToArray($str1, $encoding);
      $mb_str2 = mbStringToArray($str2, $encoding);
    
      $len = $mb_len1 > $mb_len2 ? $mb_len1 : $mb_len2;
    
      $dp = array();
      for ($i = 0; $i <= $len; $i++) {
        $dp[$i] = array();
        $dp[$i][0] = 0;
        $dp[0][$i] = 0;
      }
    
      for ($i = 1; $i <= $mb_len1; $i++) {
        for ($j = 1; $j <= $mb_len2; $j++) {
          if ($mb_str1[$i - 1] == $mb_str2[$j - 1]) {
            $dp[$i][$j] = $dp[$i - 1][$j - 1] + 1;
          } else {
            $dp[$i][$j] = $dp[$i - 1][$j] > $dp[$i][$j - 1] ? $dp[$i - 1][$j] : $dp[$i][$j - 1];
          }
        }
      }
    
      return $dp[$mb_len1][$mb_len2];
    }
    
    2022-12-01 10:49 回答
撰写答案
今天,你开发时遇到什么问题呢?
立即提问
热门标签
PHP1.CN | 中国最专业的PHP中文社区 | PNG素材下载 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有