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 += ai;//先加和

cnt.merge(ai, 1, Integer::sum);//判断hash表中ai是否存在 如果存在 把它的值加1 如果不存在 则在hash表中添加 ai 并把值设为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 = aleft;//获得要扔出去的元素

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;

}

}

相关推荐
云水一下3 分钟前
CSS3从零基础到精通(三):动感地带——过渡、动画、变形与响应式
前端·css3
寂夜了无痕5 分钟前
IntelliJ IDEA 高效配置:新建文件自动生成作者与时间注释
java·ide·intellij-idea
leonidZhao13 分钟前
Java 25新特性:模块导入申明
java
KaMeidebaby35 分钟前
卡梅德生物技术快报|Western Blot 实验应用:肺肠轴机制研究全流程技术解析
前端·数据库·人工智能·算法·百度
weixin_4896900238 分钟前
【IDEA 2025.2.4】 Maven 仅能手动 Reload All Maven Projects 问题解决
java·maven·intellij-idea
雨辰AI38 分钟前
MySQL 迁移至达梦 DM9 完整改造指南|99% SQL 零改动
java·开发语言·数据库·sql·mysql·政务
golang学习记38 分钟前
Intellij IDEA 2026重磅更新!开发体验大升级
java·ide·intellij-idea
弹简特41 分钟前
【Java项目-轻聊】05-AI赋能设计接口文档
java·开发语言
达达爱吃肉1 小时前
claude 接入deepseek 运行报错
java·服务器·前端
OctShop大型商城源码1 小时前
OctShop对比JAVA商城源码_OctShop大型专业级多用户商城源码
java·开发语言·商城系统·小程序商城·octshop