哈希表(一)

news2025/1/6 20:27:31

一、基础知识

哈希表的优点:

查找key的时间效率是O(1)

什么时候要用到哈希表:

查询元素的出现问题(是否出现过,是否在集合里,出现次数等)

哈希表的三种数据结构:

数组(数据范围较小时)

set(数据范围很大或者数据很散乱时)

map(需要同时用到key和value时)

二、数组

    bool isAnagram(string s, string t) {
    //仅26个英文字母,且是连续的,数据范围可为[0,25],用数组
    
    int hash[26]={0}; //初始化,记录字母出现次数的哈希数组
    if(s.size()!=t.size()){
        return 0;
    }
    for(int i=0;i<s.size();i++){ //遍历字符串,哈希计数
        hash[s[i]-'a']++; //映射,key值是字母-'a'(作差得起点),value是出现次数
        hash[t[i]-'a']--;
    }
    for(int i=0;i<26;i++){ //遍历哈希数组,看哈希计数是否为0(先+后-,若相等,最后为0)
        if(hash[i])
          return 0;
    }
    return 1;
    }

 对于26个连续的小写英文字母,要记录其出现的次数,用哈希数组即可;

遍历字符串,在hash[s[i]-'a']的位置进行++或--的操作;

最后判断哈希数组中是否全为0,若是则证明两个字符串是字母异位词。

三、set

vector<int> intersection(vector<int>& nums1, vector<int>& nums2) {
        
     //unordered set自动去重,用来定义result
     unordered_set<int> result; //注意要写<int>
     //直接将数组1转变为set,便于判断数组2的元素是否在数组1集合中,减免了对1的for遍历
     unordered_set<int> nums1_set(nums1.begin(),nums1.end()); //转换是.begin(),.end()
     for(int i=0;i<nums2.size();i++){
        if(nums1_set.find(nums2[i])!=nums1_set.end()){
            //能找到,说明是交集元素
            result.insert(nums2[i]);
        }
     }
     return vector<int>(result.begin(),result.end()); //最终返回的是数组,转化为vector<int>
    }

对于装有零散数据(数据范围很大)的集合,用set

 将nums1数组变为集合1,遍历nums2数组,判断元素是否存在集合1中

若是,则加入result(unordered_set自动去重)中

四、map

vector<int> twoSum(vector<int>& nums, int target) {
        //用哈希map来存放遍历过的元素,数值作为key,索引作为value(哈希表查找key的效率是o(1),查找很快)

        //遍历数组元素,首先求该元素的配对元素,然后判断它是否在遍历过的map中,没有则将当前元素加入map,继续遍历下一个

        unordered_map<int,int> map;
        for(int i=0;i<nums.size();i++){
            int s=target-nums[i];
            auto iter=map.find(s); //查找key,找到时返回位置指针,找不到时返回.end()
            if(iter!=map.end()){
                //说明找到了,直接返回答案即可
                return {iter->second,i};//要写second,不能写value
            }
            map[nums[i]]=i;
        }
        return {};
    }

 对于既要用到数组元素值(key),又要用到索引(value)的情况,用map

(key是要查找的东西,所以将元素值作为key)

遍历数组元素,判断和当前元素对应的值(terget-nums[i])是否存在于遍历过的元素集合map中,

若是,则返回答案;若不是,则将当前元素加入map中,继续遍历下一元素

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

从自身经历浅谈对于C++/Java的认识

1.声明 因为一些其他的原因&#xff0c;我决定从C转到java方向学习&#xff0c;后期可能就要换方向了&#xff0c;以后主要学习这个java相关的这个技术了&#xff0c;起码暂时不会学习这个C里面的内容了&#xff1b; 2.我的感慨 当时选方向的时候&#xff0c;我自己就是选的…

甘蔗茎节检测系统源码分享

甘蔗茎节检测检测系统源码分享 [一条龙教学YOLOV8标注好的数据集一键训练_70全套改进创新点发刊_Web前端展示] 1.研究背景与意义 项目参考AAAI Association for the Advancement of Artificial Intelligence 项目来源AACV Association for the Advancement of Computer Vis…

插座检测系统源码分享

插座检测检测系统源码分享 [一条龙教学YOLOV8标注好的数据集一键训练_70全套改进创新点发刊_Web前端展示] 1.研究背景与意义 项目参考AAAI Association for the Advancement of Artificial Intelligence 项目来源AACV Association for the Advancement of Computer Vision …

Docker 天池代码提交

参考零基础入门Docker-cuda练习场_学习赛_天池大赛-阿里云天池的赛制 (aliyun.com) ​ 在Docker零基础入门-CSDN博客中我已经安装了docker,现在开始创建自己的镜像仓库。 1. 开通阿里云容器镜像服务(镜像仓库) 进入容器镜像服务 (aliyun.com) 1.1. 创建个人实例 点击“…

.net 未能加载文件或程序集“System.Diagnostics.DiagnosticSource, Version=6.0.0.1 解决方案

.net webapi 项目以前用的正常&#xff0c;重装server2019后&#xff0c;又把oracle客户端从11g升级成19c&#xff0c;修改了连接字符串后&#xff0c;其他网站都正常&#xff0c;唯独这个webapi报错 报错信息&#xff1a; 未能加载文件或程序集“System.Diagnostics.Diagnos…

Elasticsearch黑窗口启动乱码问题解决方案

问题描述 elasticsearch启动后有乱码现象 解决方案&#xff1a; 提示&#xff1a;这里填写该问题的具体解决方案&#xff1a; 到 \config 文件下找到 jvm.options 文件 打开后 在文件末尾空白处 添加 -Dfile.encodingGBK 保存后重启即可。

精密制造的革新:光谱共焦传感器与工业视觉相机的融合

在现代精密制造领域&#xff0c;对微小尺寸、高精度产品的检测需求日益迫切。光谱共焦传感器凭借其非接触、高精度测量特性脱颖而出&#xff0c;而工业视觉相机则以其高分辨率、实时成像能力著称。两者的融合&#xff0c;不仅解决了传统检测方式在微米级别测量上的局限&#xf…

MySQL 应对大量并发连接之道

《》 在当今的互联网时代&#xff0c;数据库面临着越来越多的并发连接请求。对于 MySQL 来说&#xff0c;如何有效地处理大量的并发连接成为了一个关键问题。本文将探讨 MySQL 处理大量并发连接的方法和策略。 一、并发连接带来的挑战 当 MySQL 数据库面临大量并发连接时&am…

使用 sponge + dtm 轻松实现秒杀抢购服务(HTTP),彻底解决库存与订单数据不一致的难题

秒杀场景的挑战 秒杀是电商中常见的抢购商品场景&#xff0c;其技术特点是瞬间请求量巨大&#xff0c;对服务的性能和一致性要求极高。即使服务出现崩溃&#xff0c;也必须确保库存扣减和订单生成保持一致&#xff0c;避免出现超卖或超买的现象。通过使用 dtm&#xff08;分布…

基于Springboot+Vue的高校体育运动会比赛系统(含源码+数据库)

1.开发环境 开发系统:Windows10/11 架构模式:MVC/前后端分离 JDK版本: Java JDK1.8 开发工具:IDEA 数据库版本: mysql5.7或8.0 数据库可视化工具: navicat 服务器: SpringBoot自带 apache tomcat 主要技术: Java,Springboot,mybatis,mysql,vue 2.视频演示地址 3.功能 该系统…

根据软件架构设计与评估的叙述开发一套机器学习应用开发平台

案例 阅读以下关于软件架构设计与评估的叙述&#xff0c;回答问题 1和问题 2。 【说明】 某公司拟开发一套机器学习应用开发平台&#xff0c;支持用户使用浏览器在线进行基于机器学习的智能应用开发活动。该平台的核心应用场景是用户通过拖拽算法组件灵活定义机器学习流程&…

如何用一段文字或一张图片生成一段视频?

找了下AI视频工具的排行&#xff0c;发现在这款国内好多大模型的AI视频工具都排在前面。测试了好几款&#xff0c;整体感觉还是非常不错&#xff0c;除了生成的时间比较短&#xff0c;清晰度和效果比自己找的会好很多。 AI视频工具文成视频成品展示 一个视频生成的时间大概是5-…

【CTF刷题8】2024.9.26

ps:源自CTFhub 基础认证&#xff1a; 在HTTP中&#xff0c;基本认证&#xff08;英语&#xff1a;Basic access authentication&#xff09;是允许http用户代理&#xff08;如&#xff1a;网页浏览器&#xff09;在请求时&#xff0c;提供 用户名 和 密码 的一种方式。详情请查…

什么是智慧党建?可视化大屏如何推动高质量党建?

在数字化时代&#xff0c;党建工作迎来了新的发展机遇。智慧党建&#xff0c;作为新时代党建工作的创新模式&#xff0c;正逐渐成为推动党的建设向高质量发展的重要力量。它不仅改变了传统的党建工作方式&#xff0c;还通过现代信息技术的应用&#xff0c;提升了党建工作的效率…

HttpSession使用方法及原理

HttpSession使用方法及原理 一、HttpSession使用流程说明二、登录概述具体 三、访问过程概述具体 一、HttpSession使用流程说明 1.用户发送登录请求到服务器。 2.服务器处理登录请求&#xff0c;调用userService.login(loginUser)。 3.如果登录成功&#xff0c;服务器调用requ…

LeetCode(Python)-贪心算法

文章目录 买卖股票的最佳时机问题穷举解法贪心解法 物流站的选址&#xff08;一&#xff09;穷举算法贪心算法 物流站的选址&#xff08;二&#xff09;回合制游戏快速包装 买卖股票的最佳时机问题 给定一个数组&#xff0c;它的第 i 个元素是一支给定股票第 i 天的价格。如果你…

大数据新视界 --大数据大厂之数据清洗工具 OpenRefine 实战:清理与转换数据

&#x1f496;&#x1f496;&#x1f496;亲爱的朋友们&#xff0c;热烈欢迎你们来到 青云交的博客&#xff01;能与你们在此邂逅&#xff0c;我满心欢喜&#xff0c;深感无比荣幸。在这个瞬息万变的时代&#xff0c;我们每个人都在苦苦追寻一处能让心灵安然栖息的港湾。而 我的…

linux命令:显示已安装在linux内核的模块的详细信息的工具modinfo详解

目录 一、概述 二、使用方法 1、基本的使用语法 2、常用选项 3、输出字段 4、获取帮助 三、示例 四、实际用途 1、诊断问题 2、模块依赖 3、参数配置 五、其他事项 一、概述 modinfo 是 Linux 系统中的一个工具&#xff0c;用于显示有关已安装内核模块的详细信息。…

MySQL 预处理语句:强大的数据库工具

《MySQL 预处理语句&#xff1a;强大的数据库工具》 在 MySQL 数据库的使用中&#xff0c;预处理语句是一个非常有用的功能。它可以提高数据库的性能、安全性和可维护性。那么&#xff0c;什么是预处理语句呢&#xff1f;它又有哪些优点呢&#xff1f;让我们一起来了解一下。 …

C++_24_适配器

A 函数对象 概念&#xff1a; ​ 重载函数调用运算符的类实例化的对象&#xff0c;就叫函数对象.又名仿函数,函数对象和&#xff08;)触发重载函数调用运算符的执行。 作用&#xff1a; ​ 为算法提供策略 示例&#xff1a; #include <iostream> using namespace s…