当前位置: 首页 > news >正文

PHP 求解两字符串所有公共子序列及最长公共子序列 支持多字节字符串


/*** 获取两字符串所有公共子序列【不连续的】 例:abc ac => ac** @param string $str1 字符串1* @param string $str2 字符串2** @return array*/
function public_sequence(string $str1, string $str2): array
{$data = [[-1, -1, '', 0, '']]; // 子序列容器【横坐标 纵坐标 当前子序列 长度 足迹】$arr  = []; // 动态规划容器$arr1 = mb_str_split($str1);$arr2 = mb_str_split($str2);$len1 = count($arr1);$len2 = count($arr2);// 动态规划for ($y = 0; $y < $len2; ++$y) {for ($x = 0; $x < $len1; ++$x) {$arr[$y][$x] = $arr1[$x] === $arr2[$y] ? 1 : 0;e($arr[$y][$x], 'n'); // 打印数据}e(); // 换行}// 寻找所有子序列$len = $len1 > $len2 ? $len1 : $len2;for ($i = 0; $i < $len; ++$i) {foreach ($data as &$value) {++$value[0]; // 横坐标++$value[1]; // 纵坐标$len = $value[3] + 1; // 长度// 纵坐标固定,横坐标增加,检验横行数据for ($x = $value[0]; $x < $len1; ++$x) {if ($value[1] >= $len2) break;if ($arr[$value[1]][$x] === 1) $data[] = [$x, $value[1], $value[2] . $arr1[$x], $len, $value[4] . '(' . $x . ',' . $value[1] . ')'];}// 横坐标固定,纵坐标增加,检验纵行数据for ($y = $value[1] + 1; $y < $len2; ++$y) {if ($value[0] >= $len1) break;if ($arr[$y][$value[0]] === 1) $data[] = [$value[0], $y, $value[2] . $arr2[$y], $len, $value[4] . '(' . $value[0] . ',' . $y . ')'];}}}return $data;
}/*** 获取两字符串所有最长公共子序列 注意:最长字符串子序列可能有多个** @param string $str1 字符串1* @param string $str2 字符串2** @return array*/
function long_public_sequence(string $str1, string $str2): array
{$data = []; // 最长子序列容器$tmp  = []; // 临时子序列容器$len = 0; // 最长子序列长度// 获取所有公共子序列$subsequence = public_sequence($str1, $str2);// 找到最长子序列长度及个数foreach ($subsequence as $value) {if ($len > $value[3]) continue;$len = $value[3];$tmp[] = $value;}// 根据最长子序列长度筛选数据foreach ($tmp as $value) {if ($len === $value[3]) $data[] = $value;}return $data;
}$str1 = '安保处的';
$str2 = '安保的';v(public_sequence($str1, $str2));
vd(long_public_sequence($str1, $str2));

执行结果:

http://www.lryc.cn/news/123537.html

相关文章:

  • linux内核bitmap之setbit汇编实现
  • Golang设计模式
  • leetcode151. 反转字符串中的单词
  • 【BASH】回顾与知识点梳理(十七)
  • 时序预测-Informer简介
  • 2023牛客第七场补题报告C F L M
  • Android使用kotlin+协程+room数据库的简单应用
  • Kubernetes pod调度约束[亲和性 污点] 生命阶段 排障手段
  • Matlab实现模拟退火算法(附上多个完整源码)
  • 前后端分离------后端创建笔记(03)前后端对接(上)
  • stable diffusion安装包和超火使用文档及提示词,数字人网址
  • 训练营:贪心篇
  • 四、Dubbo扩展点加载机制
  • [保研/考研机试] KY103 2的幂次方 上海交通大学复试上机题 C++实现
  • 时序预测 | MATLAB实现基于BP神经网络的时间序列预测-递归预测未来(多指标评价)
  • 组合模式(C++)
  • git上传问题记录
  • 通过动态IP解决网络数据采集问题
  • 可重入锁,不可重入锁,死锁的多种情况,以及产生的原因,如何解决,synchronized采用的锁策略(渣女圣经)自适应的底层,锁清除,锁粗化,CAS的部分应用
  • JSON.parse()和JSON.stringify()用法
  • Android 并发编程--阻塞队列和线程池
  • Playwright快速上手-1
  • PPT颜色又丑又乱怎么办?
  • python计算相关系数R
  • 黑马项目一阶段面试 自我介绍篇
  • 时序预测 | MATLAB实现CNN-BiGRU-Attention时间序列预测
  • 开发过程中遇到的问题以及解决方法
  • 本地oracle登录账号锁定处理,the account is locked
  • redission自定义hessian序列化
  • P8642 [蓝桥杯 2016 国 AC] 路径之谜