Leetcode 97. Interleaving String 交错字符判别 解题报告
来源:互联网 发布:马歇尔计划 知乎 编辑:程序博客网 时间:2024/06/05 05:48
1 解题思想
我的解题是参照这篇博客来的:传送门
具体来说,这道题的是想让我们判断对于字符串S3,是否由S1和S2里面的字符交互交错而成,即,把S1的每个字符保持相对有序的情况下随机插入到S2是否能得到S3(这里的描述,S1和S2可以互换)
首先来说,传统的递归方式肯定会超时,肯定不行。
这里的做法是说将S1和S2展开成一个矩阵,假设长度分别为n,m,那么就是构建一个n*m的DP矩阵,使用DP的方式来进行判断。
具体来说(来自原文):
当s1到达第i个元素,s2到达第j个元素:
地图上往右一步就是s2[j-1]匹配s3[i+j-1]。
地图上往下一步就是s1[i-1]匹配s3[i+j-1]。
示例:s1=”aa”,s2=”ab”,s3=”aaba”。标1的为可行。最终返回右下角。
0 a b
0 1 1 0
a 1 1 1
a 1 0 1
2 原题
Given s1, s2, s3, find whether s3 is formed by the interleaving of s1 and s2.For example,Given:s1 = "aabcc",s2 = "dbbca",When s3 = "aadbbcbcac", return true.When s3 = "aadbbbaccc", return false.
3 AC解
public class Solution { // public boolean isInterleave(String s1, String s2, String s3) { int n=s1==null?0:s1.length(); int m=s2==null?0:s2.length(); int k=s3==null?0:s3.length(); if(n+m != k) return false; char[] S1 = s1.toCharArray(); char[] S2 = s2.toCharArray(); char[] S3 = s3.toCharArray(); boolean map[][]=new boolean[n+1][m+1]; //根据上面说的方式,判断状态 for(int i=0;i<=n;i++){ for(int j=0;j<=m;j++){ if( i==0 && j==0){ map[i][j] = true; } else if (i==0){ map[i][j] = map[i][j-1] & S3[i+j-1]==S2[j-1]; } else if (j==0){ map[i][j] = map[i-1][j] & S3[i+j-1]==S1[i-1]; } else { map[i][j] = (map[i][j-1] & S3[i+j-1]==S2[j-1]) | (map[i-1][j] & S3[i+j-1]==S1[i-1]); } } } return map[n][m]; }}
0 0
- Leetcode 97. Interleaving String 交错字符判别 解题报告
- leetCode 97.Interleaving String (交错字符串) 解题思路和方法
- [leetcode] 97. Interleaving String 解题报告
- [Leetcode] 97. Interleaving String 解题报告
- 【LeetCode】Interleaving String 解题报告
- [LeetCode] Interleaving String 解题报告
- LeetCode(97) Interleaving String解题报告
- Interleaving String解题报告
- LeetCode 97: Interleaving String 字符串交错
- 交错字符串 Interleaving String
- leetcode 97. Interleaving String(字符串交错出现) DFS深度优先遍历+DP
- LeetCode 97. Interleaving String
- [LeetCode]97.Interleaving String
- [Leetcode] 97. Interleaving String
- LeetCode --- 97. Interleaving String
- [leetcode] 97.Interleaving String
- [leetcode] 97.Interleaving String
- leetcode 97. Interleaving String
- QQ首位产品经理吴宵光:腾讯17年旅途的14个关键点
- Java版-九大排序算法
- 缺少编译库libgmp.so.3: cannot open shared object file: No such file解决方案
- 编程之美读书笔记-寻找数组中的最大值和最小值
- 高效的批量数据库操作
- Leetcode 97. Interleaving String 交错字符判别 解题报告
- JVM参数配置大全
- 奇妙的等式 && 精妙的证明(二)
- 走进tomcat之一个简单Web服务器
- 段选择符和段寄存器
- android实现移动按钮
- 为 自定义 Cell 上的控件(Label、ImageView)添加手势
- amazon 3道笔试题
- 自定义Dialog android Dialog