c++哈希表

本文探讨了哈希表在C++中的应用,特别是STL中的HashMap实现。哈希表通过哈希函数提供快速查找功能,尽管HashMap未被正式纳入C++标准模板库,但它在各种实现中广泛使用。哈希表的核心是哈希函数和解决冲突的方法,通过映射关键字到数组下标存储元素。在HashMap中,插入和查找操作涉及获取key,通过哈希函数确定桶号,然后在相应桶内进行操作。良好的哈希函数和比较函数能优化查找效率,尤其是在桶内元素较少时。
摘要由CSDN通过智能技术生成

在刷初级算法的字符串有好多关于哈希表的内容 所以作词笔记,强化哈希。

首先哈希表的作用是什么?它可以快速的查找。key-value值。 key值是唯一的。就例如一个统计某几人的身高。

如下是STL标准库map容器的实例。 map不允许容器中有重复key值元素

map<string, string> PersonMap;
PersonMap["张三"] = "183";
PersonMap["张四"] = "186";
PersonMap["张五"] = "173";
PersonMap["张六"] = "160";

当你使用如上的STL容,在解决某类问题你会发现十分的简单。使用其内置函数find(),直接查找。

Hash-map

Hash-map他是基于Hash-table的实现,虽然hash_map目前并没有纳入C++ 标准模板库中,但几乎每个版本的STL都提供了相应的实现。而且应用十分广泛。

hash_map基于hash table(哈希表)。 哈希表最大的优点,就是把数据的存储和查找消耗的时间大大降低,几乎可以看成是常数时间;而代价仅仅是消耗比较多的内存。然而在当前可利用内存越来越多的情况下,用空间换时间的做法是值得的。另外,编码比较容易也是它的特点之一。

其基本原理是:使用一个下标范围比较大的数组来存储元素。可以设计一个函数(哈希函数,也叫做散列函数),使得每个元素的关键字都与一个函数值(即数组下标,hash值)相对应,于是用这个数组单元来存储这个元素ÿ

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值