【力扣】面试经典150题——哈希表

文章目录

  • [383. 赎金信](#383. 赎金信)
  • [205. 同构字符串](#205. 同构字符串)
  • [290. 单词规律](#290. 单词规律)

383. 赎金信

给你两个字符串:ransomNote 和 magazine ,判断 ransomNote 能不能由 magazine 里面的字符构成。

如果可以,返回 true ;否则返回 false 。

magazine 中的每个字符只能在 ransomNote 中使用一次。

java 复制代码
class Solution {
    public boolean canConstruct(String ransomNote, String magazine) {
        if(ransomNote.length() > magazine.length()){
            return false;
        }

        int[] cnt = new int[26];
        for(char c : magazine.toCharArray()){
            cnt[c - 'a']++;
        }
        for(char c : ransomNote.toCharArray()){
            cnt[c - 'a']--;
            if(cnt[c - 'a'] < 0){
                return false;
            }
        }
        return true;
    }
}

205. 同构字符串

给定两个字符串 s 和 t ,判断它们是否是同构的。

如果 s 中的字符可以按某种映射关系替换得到 t ,那么这两个字符串是同构的。

每个出现的字符都应当映射到另一个字符,同时不改变字符的顺序。不同字符不能映射到同一个字符上,相同字符只能映射到同一个字符上,字符可以映射到自己本身。

java 复制代码
class Solution {
    public boolean isIsomorphic(String s, String t) {
        Map<Character, Character> s2t = new HashMap<Character, Character>();
        Map<Character, Character> t2s = new HashMap<Character, Character>();

        int len = s.length();
        for(int i = 0; i < len; i++){
            char x = s.charAt(i), y = t.charAt(i);
            if((s2t.containsKey(x) && s2t.get(x) != y) || (t2s.containsKey(y) && t2s.get(y) != x)){  //当字符重复时,查看由键所得的值是否匹配
                return false;
            }
            s2t.put(x, y);
            t2s.put(y, x);
        }
        return true;

    }
}

290. 单词规律

给定一种规律 pattern 和一个字符串 s ,判断 s 是否遵循相同的规律。

这里的 遵循 指完全匹配,例如, pattern 里的每个字母和字符串 s 中的每个非空单词之间存在着双向连接的对应规律。

java 复制代码
class Solution {
    public boolean wordPattern(String pattern, String str) {
        Map<String, Character> str2ch = new HashMap<String, Character>();
        Map<Character, String> ch2str = new HashMap<Character, String>();

        int m = str.length();
        int i = 0;
        for(int p = 0; p < pattern.length(); ++p){
            char ch = pattern.charAt(p);
            if(i >= m){
                return false;
            }
            int j = i;
            while(j < m && str.charAt(j) != ' '){
                j++;
            }
            String tmp = str.substring(i, j);
            if(str2ch.containsKey(tmp) && str2ch.get(tmp) != ch){
                return false;
            }
            if(ch2str.containsKey(ch) && !tmp.equals(ch2str.get(ch))){
                return false;
            }
            str2ch.put(tmp, ch);
            ch2str.put(ch, tmp);
            i = j + 1;
        }
        return i >= m;
    }
}

相关推荐
风筝在晴天搁浅2 小时前
快手/字节 CodeTop LeetCode 415.字符串相加
算法·leetcode
米粒14 小时前
力扣算法刷题 Day 64 Floyd算法 & A* 算法 & 总结篇
算法·leetcode·职场和发展
青山师4 小时前
动态代理深度解析:JDK与CGLIB底层实现与实战
java·设计模式·面试·动态代理·java面试·cglib
MonkeyKing71555 小时前
iOS 开发 ARC 与 MRC 底层原理及区别
ios·面试
盏灯6 小时前
以前有一个同事说:最讨厌下班提需求又没电脑在身边...
前端·后端·面试
AI人工智能+电脑小能手7 小时前
【大白话说Java面试题】【Java基础篇】第39题:说说反射的用途及实现原理,Java获取反射(Class)的三种方法
java·开发语言·后端·python·面试
jieyucx7 小时前
零基础入门:一文看懂哈希算法、哈希表与 Go map
golang·哈希算法·散列表·map·哈希表
Liangwei Lin8 小时前
LeetCode 41. 缺失的第一个正数
数据结构·算法·leetcode
小雅痞8 小时前
[Java][Leetcode hard] 76. 最小覆盖子串
java·算法·leetcode
研究点啥好呢9 小时前
Momenta后端开发面试题精选:10道高频考题+答案解析(数据产线方向)
c++·python·面试·求职招聘