Leetcode75 Day2

81 阅读1分钟

携手创作,共同成长!这是我参与「掘金日新计划 · 8 月更文挑战」的第2天,点击查看活动详情

第一题: image.png

同构字符串,经典,但是并没有想到用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;
    }
}

第二题:

image.png

有很大的问题,我感觉这种子序列的题目很常考!

有必要多搞几种写法:

  1. 双指针

重点:其实想清楚,前面比如找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;
    }
}

但是还是出错了,,,

image.png

原来是忘记了添加长度够了之后直接return true

image.png

复杂度:

image.png

  1. 动态规划 力扣解析:

image.png

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;
    }
}

image.png

image.png

image.png

image.png

image.png

image.png