news 2026/4/3 3:02:31

Leetcode:97.交错字符串

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Leetcode:97.交错字符串

给定三个字符串s1s2s3,请你帮忙验证s3是否是由s1s2交错组成的。

两个字符串st交错的定义与过程如下,其中每个字符串都会被分割成若干非空子字符串:

  • s = s1 + s2 + ... + sn
  • t = t1 + t2 + ... + tm
  • |n - m| <= 1
  • 交错s1 + t1 + s2 + t2 + s3 + t3 + ...或者t1 + s1 + t2 + s2 + t3 + s3 + ...

注意:a + b意味着字符串ab连接。

示例 1:

输入:s1 = "aabcc", s2 = "dbbca", s3 = "aadbbcbcac"输出:true

示例 2:

输入:s1 = "aabcc", s2 = "dbbca", s3 = "aadbbbaccc"输出:false

示例 3:

输入:s1 = "", s2 = "", s3 = ""输出:true

提示:

  • 0 <= s1.length, s2.length <= 100
  • 0 <= s3.length <= 200
  • s1s2、和s3都由小写英文字母组成

进阶:您能否仅使用O(s2.length)额外的内存空间来解决它?

还是直接上代码,特别简单的动态规划:

class Solution { /**近乎白送分的题,一看就是动态规划,但是可能稍微复杂一点点的:三维的吗? 三维也不是不能解,就是做起来比较麻烦,我们用二维来替代:既然s3的某个长度可以用s1的某个 长度和s2的某个长度拼出,那这段里s3的长度肯定等于s1和s2之和 */ public boolean isInterleave(String s1, String s2, String s3) { /**先转成字符数组方便操作 */ char[] sArr1 = s1.toCharArray(); char[] sArr2 = s2.toCharArray(); char[] sArr3 = s3.toCharArray(); int m = sArr1.length; int n = sArr2.length; int o = sArr3.length; if(m == 0 && n == 0 && o == 0) { return true; } if(m + n != o) { return false; } /**dp[i][j]表示s1的前i个字符和s2的前j个字符是否可以拼出s3的前i+j个字符*/ boolean[][] dp = new boolean[m+1][n+1]; /**s1的前0个字符和s2的前0个字符肯定能拼出s3的前0个字符*/ dp[0][0] = true; /**初始化第一行和第一列,第一列是s1的前i个字符和s3的前i个字符是否相等*/ for(int i = 1; i <= m ;i++) { dp[i][0] = dp[i - 1][0] && sArr1[i - 1] == sArr3[i-1]; } /**第一列是s2的前j个字符和s3的前j个字符是否相等 */ for(int j = 1; j <= n; j++) { dp[0][j] = dp[0][j - 1] && sArr2[j - 1] == sArr3[j - 1]; } /**考虑一般的位置*/ for(int i = 1; i <= m; i++) { for(int j = 1; j <= n; j++) { dp[i][j] = (dp[i-1][j] && sArr1[i - 1] == sArr3[i + j - 1]) || (dp[i][j - 1] && sArr2[j - 1] == sArr3[i + j - 1]); } } /**要求的是s1的整个和s2的整个能否拼出s3的整个 */ return dp[m][n]; } }

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/3 3:01:14

<span class=“js_title_inner“>自动化立体仓库技术标书--详细版</span>

导语 大家好&#xff0c;我是社长&#xff0c;老K。专注分享智能制造和智能仓储物流等内容。欢迎大家使用我们的仓储物流技术AI智能体。 新书《智能物流系统构成与技术实践》 新书《智能仓储项目出海-英语手册》 新书《智能仓储自动化项目&#xff1a;避坑手册》 新书《智能仓储…

作者头像 李华
网站建设 2026/3/19 23:41:46

SSM计算机毕设之基于SSM的高校共享单车管理系统设计与实现(完整前后端代码+说明文档+LW,调试定制等)

博主介绍&#xff1a;✌️码农一枚 &#xff0c;专注于大学生项目实战开发、讲解和毕业&#x1f6a2;文撰写修改等。全栈领域优质创作者&#xff0c;博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围&#xff1a;&am…

作者头像 李华
网站建设 2026/4/1 20:43:28

一阶小车倒立摆PID闭环稳定控制系统matlab仿真

✅作者简介&#xff1a;热爱科研的Matlab仿真开发者&#xff0c;擅长毕业设计辅导、数学建模、数据处理、建模仿真、程序设计、完整代码获取、论文复现及科研仿真。&#x1f34e; 往期回顾关注个人主页&#xff1a;Matlab科研工作室&#x1f447; 关注我领取海量matlab电子书和…

作者头像 李华