交错字符串
时间:2022-07-22
本文章向大家介绍交错字符串,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
问题描述:
给定三个字符串 s1, s2, s3, 验证 s3 是否是由 s1 和 s2 交错组成的。
示例 1:
输入: s1 = "aabcc", s2 = "dbbca", s3 = "aadbbcbcac"
输出: true
示例 2:
输入: s1 = "aabcc", s2 = "dbbca", s3 = "aadbbbaccc"
输出: false
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/interleaving-string
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
解决方案
首先得判断s1与s2的长度之和是否等于s3的长度,若不相等则s1和s2怎么组合都不可能匹配出s3。
该问题可以转化为每次从s1或者s2中顺序取一个元素,最终直到s1, s2取完若能够组成s3,则认为s3可以由s1, s2交错组成。我们的每步操作只要选择s1或者s2即可。
定义dp[i] [j] 为s1从i开始,s2从j开始能否匹配上s3。
转移方程:
若s1的当前元素等于s3的当前元素,判断从s1的下一个元素和s2当前元素开始能否匹配上s3的下一个元素开始的字符串,若能匹配上,则当前位置选择s1可以完成匹配;
若s2的当前元素等于s3的当前元素,判断从s2的下一个元素和s1当前元素开始能否匹配上s3的下一个元素开始的字符串,若能匹配上,则当前位置选择s2可以完成匹配;
否则就不能完成匹配。
baseline:
上式中,M为s1的长度,N为s2的长度。
第一个式子s1,s2都用完了,s3也完了,返回true
第二个式子时s2用完了,s1还有,此时需要判断s1剩下的元素能否与s3剩下的元素完成匹配
第二个式子时s1用完了,s2还有,此时需要判断s2剩下的元素能否与s3剩下的元素完成匹配
代码如下:
class Solution {
public boolean isInterleave(String s1, String s2, String s3) {
if(s1.length() + s2.length() != s3.length()){
return false;
}
int M = s1.length();
int N = s2.length();
// dp[i][j] 为s1从i开始,s2从j开始能否匹配上 s3从i + j开始
boolean[][] dp = new boolean[M + 1][N + 1];
// init
dp[M][N] = true;
// s2没了
for(int i = M - 1; i >= 0; i--){
if(s1.charAt(i) == s3.charAt(N + i)){
dp[i][N] = true;
}else{
break;
}
}
for(int j = N - 1; j >= 0; j--){
if(s2.charAt(j) == s3.charAt(M + j)){
dp[M][j] = true;
}else{
break;
}
}
for(int i = M - 1; i >= 0; i--){
for(int j = N - 1; j >= 0; j--){
dp[i][j] = (s1.charAt(i) == s3.charAt(i + j) && dp[i + 1][j]) || (s2.charAt(j) == s3.charAt(i + j) && dp[i][j + 1]);
}
}
return dp[0][0];
}
}
- 厚土Go学习笔记 | 05. 函数
- Implement Domain Object in Golang
- 厚土Go学习笔记 | 04. 导入和导出的不同 用math.Pi来举例
- 厚土Go学习笔记 | 03. 数学运算的随机数
- Nodejs学习笔记(十一)--- 数据采集器示例(request和cheerio)
- 厚土Go学习笔记 | 02. 打印当前时间time.Now()时不我待
- 厚土Go学习笔记 | 01. Hello World开篇
- Golang精编100题
- IntelliJ idea配置Go开发环境
- 仰望PHPSHE1.5漏洞
- Golang负载均衡
- 构建Docker镜像两种方式的比较-Dockerfile方式和S2I方式
- Golang单例模式
- 2018,我要Axublog。
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- c++实例之通讯录管理系统之显示联系人功能(三)
- c++实例之通讯录管理系统之删除联系人功能(四)
- springboot检索之Elasticsearch简介
- c++实例之通讯录管理系统之查找联系人功能(五)
- 【python-leetcode424-滑动窗口法】替换后的最长重复字符
- c++实例之通讯录管理系统之修改联系人功能(六)
- 解决arxiv.org打开pdf缓慢问题
- c++实例之通讯录管理系统之清空联系人功能(七)
- springboot任务之定时任务
- springboot检索之整合elasticsearch并使用jest操作
- springboot任务之邮件任务
- springboot安全之整合spring security实现(只有登录才有权限、不同用户显示不同内容、记住我)
- springboot任务之异步任务
- springboot缓存之@Cacheable中常用参数
- springboot开发之添加员工