携手创作,共同成长!这是我参与「掘金日新计划 · 8 月更文挑战」的第2天,点击查看活动详情
第一题:
同构字符串,经典,但是并没有想到用Map来存储,然后判断,如果有这个key的话(containKey方法)就接着判断这个key对应的值和不和对应的值对应。反过来同理,如果这个key没有的话就会put进去。
class Solution {
public boolean isIsomorphic(String s, String t) {
Map<Character, Character> map = new HashMap<>();
Map<Character, Character> map1 = new HashMap<>();
int len = s.length();
for (int i = 0; i < len; ++i) {
char x = s.charAt(i), y = t.charAt(i);
if ((map.containsKey(x) && map.get(x) != y) || (map1.containsKey(y) && map1.get(y) != x)) {
return false;
}
map.put(x, y);
map1.put(y, x);
}
return true;
}
}
第二题:
有很大的问题,我感觉这种子序列的题目很常考!
有必要多搞几种写法:
- 双指针
重点:其实想清楚,前面比如找abcabcbabcababcabcabbcbcal里面找cal,如果你一眼看到了最后的cal很ok,最后有说明前面也有符合的,因为题目不是要求连接的,只要存在且数据对就行,所以我们只要在前面找到一个,就可以接着找下一个了,不管后面有没有出现c,第一个出现的c永远符合情况
其实要想清楚一个问题,就是,如果前面后面的都有下面同一个字符串的头部,比如abbbbbbabbb
要找a的话如果后面一个字符串存在前面一个必定存在,所以只要一直维护第一个值就行
还要注意的一点就是,要判断前面一个字符串是否为空!!!
是空的话就返回true,肯定是子串
然后就会自然而然想到判断后面一个字符串是不是空,是空返回true。
大错特错!
不要想当然,一定要想一遍,后面一个字符串是空的时候说明必定不是字字符串!!(前面一个是空前面已经判断过了)
class Solution {
public static boolean isSubsequence(String s, String t) {
/*
* 其实要想清楚一个问题,就是,如果前面后面的都有下面同一个字符串的头部,比如abbbbbbabbb
要找a的话如果后面一个字符串存在前面一个必定存在,所以只要一直维护第一个值就行
* */
// 双指针
// 注意判空
if(s.length()==0) {
return true;
}
if(t.length()==0){
return false;
}
int flag = 0;
for (int i = 0; i < t.length(); i++) {
if (t.charAt(i) == s.charAt(flag)) {
flag++;
}
}
if (flag == s.length()) {
// 说明已经全部找到了
return true;
}
return false;
}
}
官方写的是:
class Solution {
public boolean isSubsequence(String s, String t) {
int n = s.length(), m = t.length();
int i = 0, j = 0;
while (i < n && j < m) {
if (s.charAt(i) == t.charAt(j)) {
i++;
}
j++;
}
return i == n;
}
}
但是还是出错了,,,
原来是忘记了添加长度够了之后直接return true
复杂度:
- 动态规划 力扣解析:
class Solution {
public boolean isSubsequence(String s, String t) {
int n = s.length(), m = t.length();
int[][] f = new int[m + 1][26];
for (int i = 0; i < 26; i++) {
f[m][i] = m;
}
for (int i = m - 1; i >= 0; i--) {
for (int j = 0; j < 26; j++) {
if (t.charAt(i) == j + 'a')
f[i][j] = i;
else
f[i][j] = f[i + 1][j];
}
}
int add = 0;
for (int i = 0; i < n; i++) {
if (f[add][s.charAt(i) - 'a'] == m) {
return false;
}
add = f[add][s.charAt(i) - 'a'] + 1;
}
return true;
}
}