哈希表示例

示例1

两数之和

"两数之和"(Two Sum)是LeetCode上的一个经典算法问题,编号为1,它要求在一个整数数组nums中找到两个不同的索引ij,使得nums[i] + nums[j] == target

问题描述: 给定一个整数数组 nums 和一个整数目标值 target,请在该数组中找出和为目标值 target 的那两个整数,并返回它们的数组下标。

import java.util.HashMap;
import java.util.Map;public class TwoSum {public static int[] twoSum(int[] nums, int target) {Map<Integer, Integer> map = new HashMap<>();for (int i = 0; i < nums.length; i++) {int complement = target - nums[i];if (map.containsKey(complement)) {return new int[] { map.get(complement), i };}map.put(nums[i], i);}throw new IllegalArgumentException("No two sum solution");}public static void main(String[] args) {int[] nums = {2, 7, 11, 15};int target = 9;int[] result = twoSum(nums, target);System.out.println(Arrays.toString(result)); // 输出: [0, 1]}
}

详细说明

  • 使用 HashMap 来存储数组中的元素及其对应的索引。

  • 遍历数组,对于每个元素,计算其补数(即 target - nums[i])。

  • 检查 HashMap 中是否存在该补数,如果存在,则找到了两个数,它们的和为 target

  • 如果不存在,则将当前元素及其索引存入 HashMap 中。

  • 该算法的时间复杂度为 O(n),因为只需遍历数组一次。

示例2

四数之和

"四数之和"(4Sum)是LeetCode上的一个经典算法问题,编号为18。该问题要求在一个整数数组nums中找到所有不重复的四个元素组合,使得这四个元素之和等于给定的目标值target

问题描述:给定四个整数数组A, B, C, D,计算有多少个元组 (i, j, k, l) 使得 A[i] + B[j] + C[k] + D[l] = 0

import java.util.HashMap;
import java.util.Map;public class FourSumII {public static int fourSumCount(int[] A, int[] B, int[] C, int[] D) {Map<Integer, Integer> map = new HashMap<>();for (int a : A) {for (int b : B) {map.put(a + b, map.getOrDefault(a + b, 0) + 1);}}int count = 0;for (int c : C) {for (int d : D) {count += map.getOrDefault(-(c + d), 0);}}return count;}public static void main(String[] args) {int[] A = {1, 2};int[] B = {-2, -1};int[] C = {-1, 2};int[] D = {0, 2};System.out.println(fourSumCount(A, B, C, D)); // 输出: 2}
}

详细说明

  • 使用 HashMap 来存储数组 AB 中所有可能的两数之和及其出现次数。

  • 遍历数组 CD,对于每一对 (c, d),计算其补数 -(c + d)

  • 检查 HashMap 中是否存在该补数,如果存在,则将对应的出现次数累加到结果中。

  • 该算法的时间复杂度为 O(n^2),因为需要遍历两个数组的组合。

示例3

有效的字母异位位

在Java中,判断两个字符串是否为有效的字母异位词(Anagram),即这两个字符串是否由相同的字符组成,只是字符的排列顺序不同。

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

import java.util.HashMap;
import java.util.Map;public class Anagram {public static boolean isAnagram(String s, String t) {if (s.length() != t.length()) {return false;}Map<Character, Integer> map = new HashMap<>();for (char c : s.toCharArray()) {map.put(c, map.getOrDefault(c, 0) + 1);}for (char c : t.toCharArray()) {if (!map.containsKey(c)) {return false;}map.put(c, map.get(c) - 1);if (map.get(c) < 0) {return false;}}return true;}public static void main(String[] args) {String s = "anagram";String t = "nagaram";System.out.println(isAnagram(s, t)); // 输出: true}
}

详细说明

  • 使用 HashMap 来记录字符串 s 中每个字符的出现次数。

  • 遍历字符串 t,对于每个字符,检查 HashMap 中是否存在该字符,如果不存在则返回 false

  • 如果存在,则将对应的出现次数减一,如果出现次数小于零则返回 false

  • 最后,如果所有字符都匹配,则返回 true

  • 该算法的时间复杂度为 O(n),因为只需遍历两个字符串一次。

示例4

赎金信

在Java中解决“赎金信”问题(LeetCode 383题),核心任务是判断一个字符串ransomNote是否可以完全由另一个字符串magazine中的字符构成。这个问题的背景设定是为了不在赎金信中暴露字迹,需要从杂志上搜索各个需要的字母,组成单词来表达意思。每个字符只能使用一次,即magazine中的字符不能被重复利用。

问题描述:给定两个字符串 ransomNotemagazine,判断 ransomNote 是否可以由 magazine 中的某些字符组成。

import java.util.HashMap;
import java.util.Map;public class RansomNote {public static boolean canConstruct(String ransomNote, String magazine) {Map<Character, Integer> map = new HashMap<>();for (char c : magazine.toCharArray()) {map.put(c, map.getOrDefault(c, 0) + 1);}for (char c : ransomNote.toCharArray()) {if (!map.containsKey(c) || map.get(c) == 0) {return false;}map.put(c, map.get(c) - 1);}return true;}public static void main(String[] args) {String ransomNote = "a";String magazine = "b";System.out.println(canConstruct(ransomNote, magazine)); // 输出: false}
}

详细说明

  • 使用 HashMap 来记录字符串 magazine 中每个字符的出现次数。

  • 遍历字符串 ransomNote,对于每个字符,检查 HashMap 中是否存在该字符且出现次数大于零,如果不存在或出现次数为零则返回 false

  • 如果存在,则将对应的出现次数减一。

  • 最后,如果所有字符都匹配,则返回 true

  • 该算法的时间复杂度为 O(n),因为只需遍历两个字符串一次。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/7025.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Flutter android debug 编译报错问题。插件编译报错

下面相关内容 都以 Mac 电脑为例子。 一、问题 起因&#xff1a;&#xff08;更新 Android studio 2024.2.2.13、 Flutter SDK 3.27.2&#xff09; 最近 2025年 1 月 左右&#xff0c;我更新了 Android studio 和 Flutter SDK 再运行就会出现下面的问题。当然 下面的提示只是其…

AI导航工具我开源了利用node爬取了几百条数据

序言 别因今天的懒惰&#xff0c;让明天的您后悔。输出文章的本意并不是为了得到赞美&#xff0c;而是为了让自己能够学会总结思考&#xff1b;当然&#xff0c;如果有幸能够给到你一点点灵感或者思考&#xff0c;那么我这篇文章的意义将无限放大。 背景 随着AI的发展市面上…

Android Studio打包APK

1.导出APK安装包 如果是首次打包&#xff0c;Create new 单击蓝色对话框右边文件夹&#x1f4c2;图标 &#xff0c;选择密钥保存路径&#xff0c;然后在下方File name对话框中填写您想要名称&#xff0c;再点击OK回到密钥创建对话框。 在此对话框中填写密码&#xff08;Passwo…

ssh密钥登录GitHub时一直提示“Error: Permission denied (publickey)”

起因 环境&#xff1a;Windows10 背景&#xff1a;之前就是按照官方说明创建个rsa密钥&#xff0c;在git后台添加上&#xff0c;就行了&#xff0c;近期怎么添加怎么失败&#xff0c;总是“Error: Permission denied (publickey)”的提示&#xff01; 尝试 各种尝试&#xf…

【玩转全栈】----Django连接MySQL

阅前先赞&#xff0c;养好习惯&#xff01; 目录 1、ORM框架介绍 选择建议 2、安装mysqlclient 3、创建数据库 4、修改settings&#xff0c;连接数据库 5、对数据库进行操作 创建表 删除表 添加数据 删除数据 修改&#xff08;更新&#xff09;数据&#xff1a; 获取数据 1、OR…

软件质量与测试报告5-压力测试 JMeter 与 Badboy

A&#xff0e;百度搜索引擎压力测试 通过在Badboy下执行如下的测试场景来生成压力测试的脚本&#xff1a; a) 在Badboy的地址栏里面输入www.baidu.com&#xff0c;回车&#xff1b; b) 在右下区域打开的百度的主页上输入搜索关键字JMeter&#xff0c;回车&#xff1b; c) 在…

vim如何显示行号

:set nu 显示行号 :set nonu 不显示行号 &#xff08;vim如何使设置显示行号永久生效&#xff1a;vim如何使相关设置永久生效-CSDN博客&#xff09;

Python Typing: 实战应用指南

文章目录 1. 什么是 Python Typing&#xff1f;2. 实战案例&#xff1a;构建一个用户管理系统2.1 项目描述2.2 代码实现 3. 类型检查工具&#xff1a;MyPy4. 常见的 typing 用法5. 总结 在 Python 中&#xff0c;静态类型检查越来越受到开发者的重视。typing 模块提供了一种方式…

Linux的基本指令(上)

1.ls指令 语法&#xff1a;ls [选项] [目录或文件] 功能&#xff1a;对于⽬录&#xff0c;该命令列出该⽬录下的所有⼦⽬录与⽂件。对于⽂件&#xff0c;将列出⽂件名以及其他信息。 常用选项&#xff1a; -a 列出⽬录下的所有⽂件&#xff0c;包括以 . 开头的隐含⽂件。 -d 将…

【数据分享】1929-2024年全球站点的逐日平均能见度(Shp\Excel\免费获取)

气象数据是在各项研究中都经常使用的数据&#xff0c;气象指标包括气温、风速、降水、湿度等指标&#xff01;说到气象数据&#xff0c;最详细的气象数据是具体到气象监测站点的数据&#xff01; 有关气象指标的监测站点数据&#xff0c;之前我们分享过1929-2024年全球气象站点…

算法每日双题精讲 —— 二分查找(山脉数组的峰顶索引,寻找峰值)

&#x1f31f;快来参与讨论&#x1f4ac;&#xff0c;点赞&#x1f44d;、收藏⭐、分享&#x1f4e4;&#xff0c;共创活力社区。 &#x1f31f; 别再犹豫了&#xff01;快来订阅我们的算法每日双题精讲专栏&#xff0c;一起踏上算法学习的精彩之旅吧&#x1f4aa; 在算法的…

macOS如何进入 Application Support 目录(cd: string not in pwd: Application)

错误信息 cd: string not in pwd: Application 表示在当前目录下找不到名为 Application Support 的目录。可能的原因如下&#xff1a; 拼写错误或路径错误&#xff1a;确保你输入的目录名称正确。目录名称是区分大小写的&#xff0c;因此请确保使用正确的大小写。正确的目录名…

如何为64位LabVIEW配置正确的驱动程序

在安装 64位 LabVIEW 后&#xff0c;确保驱动程序正确配置是关键。如果您首先安装了 32位 LabVIEW 和相关驱动&#xff0c;然后安装了 64位 LabVIEW&#xff0c;需要确保为 64位 LabVIEW 安装和配置适当的驱动程序&#xff0c;才能正常访问硬件设备。以下是详细步骤&#xff1a…

《Memory Barriers a Hardware View for Software Hackers》阅读笔记

CPU 设计者引入内存屏障&#xff08;memory barriers&#xff09;是为了应对在多处理器系统&#xff08;SMP&#xff09;中&#xff0c;内存引用重排序可能导致的同步问题。尽管重排序可以提高性能&#xff0c;但在某些情况下&#xff08;如同步原语&#xff09;&#xff0c;正…

ES设置证书和创建用户,kibana连接es

1、启动好es 2、进入es容器 docker exec -it es /bin/bash 3、生成ca证书 ./bin/elasticsearch-certutil ca 注&#xff1a;两个红方框位置直接回车 4、生成cert证书 ./bin/elasticsearch-certutil cert --ca elastic-stack-ca.p12 注&#xff1a;前两个红框直接回车&am…

【安当产品应用案例100集】034-安当KSP支持密评中存储数据的机密性和完整性

安当KSP是一套获得国密证书的专业的密钥管理系统。KSP的系统功能扩展图示如下&#xff1a; 我们知道商用密码应用安全性评估中&#xff0c;需要确保存储的数据不被篡改、删除或者破坏&#xff0c;必须采用合适的安全方案来确保存储数据的机密性和完整性。KSP能否满足这个需求呢…

STM32项目分享:智能厨房安全检测系统

目录 一、前言 二、项目简介 1.功能详解 2.主要器件 三、原理图设计 四、PCB硬件设计 PCB图 五、程序设计 六、实验效果 七、资料内容 项目分享 一、前言 项目成品图片&#xff1a; 哔哩哔哩视频链接&#xff1a; STM32智能厨房安全检测系统 &#xff08;资料分…

Poetry shell --> poetry-plugin-shell

当前环境&#xff1a;Poetry (version 2.0.1) python Python 3.11.8 根据&#xff1a;https://python-poetry.org/docs/managing-environments/#bash-csh-zsh 在新版本的 poetry 执行 poetry shell 会报错 这个功能目前需要使用 poetry-plugin-shell 插件 关于 poetry-plugin-s…

第84期 | GPTSecurity周报

GPTSecurity是一个涵盖了前沿学术研究和实践经验分享的社区&#xff0c;集成了生成预训练Transformer&#xff08;GPT&#xff09;、人工智能生成内容&#xff08;AIGC&#xff09;以及大语言模型&#xff08;LLM&#xff09;等安全领域应用的知识。在这里&#xff0c;您可以找…

【JavaEE进阶】Spring留言板实现

目录 &#x1f38d;预期结果 &#x1f340;前端代码 &#x1f384;约定前后端交互接口 &#x1f6a9;需求分析 &#x1f6a9;接口定义 &#x1f333;实现服务器端代码 &#x1f6a9;lombok介绍 &#x1f6a9;代码实现 &#x1f334;运行测试 &#x1f384;前端代码实…