力扣,哈希表,(滑动窗口),242,(209),438

1.简介哈希表

哈希表(Hash Table),又称散列表,是一种通过键(Key)直接访问值(Value) 的高效数据结构。它的核心思想是:用哈希函数(Hash Function)将键映射到存储位置 ,从而在平均情况下实现 O(1) 时间复杂度的插入、删除和查找操作。

2.3种使用哈希表的方法

一般哈希表 用来快速判断一个元素是否出现集合里,只需要O (1)复杂度就可以做到,不需要遍历。 三种方法:数组、set、map

3.哈希表对应的力扣题

242. 有效的字母异位词(1)242. 有效的字母异位词

给定两个字符串 st ,编写一个函数来判断 t 是否是 s 的 字母异位词。

示例 1:

复制代码
输入: s = "anagram", t = "nagaram"
输出: true

示例 2:

复制代码
输入: s = "rat", t = "car"
输出: false

提示:

  • 1 <= s.length, t.length <= 5 * 104
  • st 仅包含小写字母

**进阶:**如果输入字符串包含 unicode 字符怎么办?你能否调整你的解法来应对这种情况?

a,理解题目,字母位置不同,字母相同

b.思路,小写字母a-z变为0-25,先s中记录每个字母出现的次数,档t再出现时,对应的下标相同的数-1,最终的值都为0时,则是有效的字母异位词

d.理解代码,伪代码

e.真正的代码,使用java

class Solution {

public boolean isAnagram(String s, String t) {

// 使用哈希表,数组

// 先创建一个数组,

int[] hash=new int[26];

for(int i=0;i<s.length();i++){

// 存入哈希数组,并且标上下标

hash[s.charAt(i)-'a']++;

} for(int i=0;i<t.length();i++){

// 如果t与s中有相同的元素,则-1;

hash[t.charAt(i)-'a']--;

}for(int i=0;i<26;i++){

if(hash[i]!=0){//有不为0时,则是多一个或者少一个字母

return false;

}

}

return true;

}

}

(2)类似的题目

相关推荐
6Hzlia6 小时前
【Hot 100 刷题计划】 LeetCode 48. 旋转图像 | C++ 矩阵变换题解
c++·leetcode·矩阵
Morwit8 小时前
【力扣hot100】 1. 两数之和
数据结构·c++·算法·leetcode·职场和发展
py有趣8 小时前
力扣热门100题之岛屿的数量(DFS/BFS经典题)
leetcode·深度优先·宽度优先
qinian_ztc9 小时前
frida 14.2.18 安装报错解决
算法·leetcode·职场和发展
cccccc语言我来了9 小时前
【C++---unordered_set/map底层封装】个不拘一格的集合。它不似有序集合那般循规蹈矩,而是以一种洒脱不羁的方式,将元素们随意地散落其中。每一个元素都是独一无二的。
开发语言·c++·哈希算法
田梓燊10 小时前
2026/4/11 leetcode 3741
数据结构·算法·leetcode
feng_you_ying_li11 小时前
c++之哈希表的介绍与实现
开发语言·c++·散列表
小肝一下13 小时前
每日两道力扣,day8
c++·算法·leetcode·哈希算法·hot100
语戚14 小时前
力扣 51. N 皇后:基础回溯、布尔数组优化、位运算全解(Java 实现)
java·算法·leetcode·力扣·剪枝·回溯·位运算
py有趣14 小时前
力扣热门100题之螺旋矩阵
算法·leetcode