java中用哈希表写题碰到的误区

两种不同的Map用法

1. 计数Map(记录出现次数)

java

复制代码
Map<Character, Integer> countMap = new HashMap<>();
countMap.put('a', 3);  // 记录'a'出现了3次
int count = countMap.get('a');  // 得到3

2. 位置索引Map(记录出现位置)

java

复制代码
Map<Character, Integer> indexMap = new HashMap<>();
indexMap.put('a', 3);  // 记录'a'最近一次出现在位置3(索引)
int index = indexMap.get('a');  // 得到3(是位置,不是次数)

下面的代码题则用到哈希表记录索引位置:

题目:给定一个字符串 s ,请你找出其中不含有重复字符的最长子串 的长度

//方法:滑动窗口+双指针

class Solution {

public int lengthOfLongestSubstring(String s) {

Map<Character,Integer> cnt = new HashMap<>();//用哈希表

int n = s.length();

int maxcount = 0;//定义最小字串的长度

int left = 0;//定义左指针 左指针会指向不含有重复字串的最左端

for(int right = 0; right < n; right++){

char c = s.charAt(right);//获取右指针指向的字符

if(cnt.containsKey(c) && cnt.get(c) >= left){//说明指向的字符存在于哈希表内部当中 这里用到的就是索引位置

left = cnt.get(c) + 1;//更新左指针位置

}

//说明指向元素没含在哈希表当中

cnt.put(c,right); 设置的也是索引

//更新最小字串长度

maxcount = Math.max(maxcount,(right - left + 1));

}

return maxcount;

}

}

下面这道题就是用哈希表记录的是个数不是索引位置:

题目:

给你一个整数数组 nums 和两个正整数 mk

请你返回 nums 中长度为 k几乎唯一 子数组的 最大和 ,如果不存在几乎唯一子数组,请你返回 0

如果 nums 的一个子数组有至少 m 个互不相同的元素,我们称它是 几乎唯一 子数组。

子数组指的是一个数组中一段连续 非空 的元素序列。

class Solution {

public long maxSum(List<Integer> nums, int m, int k) {

Integer[] a = nums.toArray(Integer[]::new);//将集合list换成数组 方便后续操作

long s = 0;//记录窗口中的和

long ans = 0;//记录最终最大的和值

//创建哈希表

Map<Integer, Integer> cnt = new HashMap<>();

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

//1.进入窗口

s += a[i];//先加和

cnt.merge(a[i], 1, Integer::sum);//判断hash表中a[i]是否存在 如果存在 把它的值加1 如果不存在 则在hash表中添加 a[i] 并把值设为1

int left = i - k + 1;//左指针

if(left < 0){ //说明窗口值不足k

continue;

}

//2.窗口已经足够k 需要更新

if(cnt.size() >= m){ //cnt中不同的元素 大于等于m个 满足要求时

ans = Math.max(ans,s); //更新ans值

}

//3.出

int out = a[left];//获得要扔出去的元素

s -= out;//先从s中减掉

int c = cnt.get(out);//获取它在hash中的次数

if(c > 1){

cnt.put(out,c-1);//如果至少出现了两次就减1次

}else{

cnt.remove(out);//如果只出现一次 那么就直接从hash表中删除就好

}

}

return ans;

}

}

相关推荐
kyriewen5 小时前
百度用6%成本碾压硅谷?中国AI把性价比玩明白了
前端·百度·ai编程
kyriewen6 小时前
你还在手动敲命令部署?GitHub Actions 让你 push 即上线,摸鱼时间翻倍
前端·面试·github
想学习java初学者6 小时前
SpringBoot整合Vertx-Mqtt多租户(优化版)
java·spring boot·后端
AC赳赳老秦6 小时前
政企内网落地:OpenClaw 离线环境深度适配方案,无外网场景下本地化模型对接与全功能使用
java·大数据·运维·python·自动化·deepseek·openclaw
weixin_449173657 小时前
在 Java 中,‌线程安全的 List‌ 主要有以下几种实现方式,它们的效率取决于具体的使用场景(尤其是读写比例):
java·线程安全的list
砚底藏山河7 小时前
股票数据API接口:如何获取股票历历史分时KDJ数据
java·python·maven
Csvn7 小时前
Pinia 状态管理
前端
不减20斤不改头像8 小时前
手机一句话开发贪吃蛇!TRAE SOLO 移动端 AI 编程实测
前端·后端
xuankuxiaoyao8 小时前
Vue.js实践-组件基础下
前端·javascript·vue.js
一棵白菜8 小时前
Claude Code + Amazon Bedrock 使用指南
前端