当前位置: 首页 > wzjs >正文

我爱建站免费空间怎么做创意短视频网站

我爱建站免费空间,怎么做创意短视频网站,做教育网站的er图,网页美工设计实训心得HashMap是一种基于哈希表实现的键值对存储结构,它通过哈希函数将键映射到数组的索引位置,支持高效的插入、查找和删除操作。其核心原理如下: 哈希函数:将键转换为数组索引。理想情况下,不同键应映射到不同索引&#xf…

在这里插入图片描述
在这里插入图片描述

  • HashMap是一种基于哈希表实现的键值对存储结构,它通过哈希函数将键映射到数组的索引位置,支持高效的插入、查找和删除操作。其核心原理如下:
    • 哈希函数:将键转换为数组索引。理想情况下,不同键应映射到不同索引,但冲突难以避免。
    • 数组+链表:使用数组作为桶(Bucket),每个桶是一个链表,解决哈希冲突(链地址法)。
    • 动态扩容:当元素数量超过容量与负载因子的乘积时,扩容并重新分配元素,保持操作高效性。
package mainimport "fmt"// Entry 键值对链表节点
type Entry struct {Key   stringValue interface{}Next  *Entry
}// HashMap 哈希表结构
type HashMap struct {buckets    []*Entry // 桶数组capacity   int      // 初始容量size       int      // 元素数量loadFactor float64  // 负载因子
}// NewHashMap 初始化哈希表
func NewHashMap(capacity int) *HashMap {return &HashMap{buckets:    make([]*Entry, capacity),capacity:   capacity,loadFactor: 0.75,}
}// hash 哈希函数(FNV-1a算法)
func (h *HashMap) hash(key string) int {const (offset = 2166136261prime  = 16777619)hash := offsetfor _, c := range key {hash ^= int(c)hash *= prime}return hash
}// getIndex 计算键对应的桶索引
func (h *HashMap) getIndex(key string) int {return h.hash(key) % h.capacity
}// Put 插入键值对
func (h *HashMap) Put(key string, value interface{}) {if float64(h.size)/float64(h.capacity) >= h.loadFactor {h.resize()}index := h.getIndex(key)entry := h.buckets[index]// 遍历链表查找键是否存在for entry != nil {if entry.Key == key {entry.Value = value // 存在则更新return}entry = entry.Next}// 不存在则插入链表头部h.buckets[index] = &Entry{Key:   key,Value: value,Next:  h.buckets[index],}h.size++
}// Get 获取值
func (h *HashMap) Get(key string) (interface{}, bool) {index := h.getIndex(key)entry := h.buckets[index]for entry != nil {if entry.Key == key {return entry.Value, true}entry = entry.Next}return nil, false
}// Delete 删除键
func (h *HashMap) Delete(key string) bool {index := h.getIndex(key)entry := h.buckets[index]var prev *Entryfor entry != nil {if entry.Key == key {if prev == nil {h.buckets[index] = entry.Next // 删除头节点} else {prev.Next = entry.Next // 中间或尾部节点}h.size--return true}prev = entryentry = entry.Next}return false
}// resize 扩容哈希表
func (h *HashMap) resize() {newCapacity := h.capacity * 2newBuckets := make([]*Entry, newCapacity)for i := 0; i < h.capacity; i++ {entry := h.buckets[i]for entry != nil {next := entry.NextnewIndex := h.hash(entry.Key) % newCapacity // 重新计算索引entry.Next = newBuckets[newIndex]          // 插入新桶头部newBuckets[newIndex] = entryentry = next}}h.buckets = newBucketsh.capacity = newCapacity
}func main() {hm := NewHashMap(2) // 初始容量设为2便于触发扩容hm.Put("name", "Alice")hm.Put("age", 30)hm.Put("lang", "Go") // 触发扩容if val, ok := hm.Get("name"); ok {fmt.Println("name:", val) // 输出 Alice}hm.Delete("age")if _, ok := hm.Get("age"); !ok {fmt.Println("age deleted") // 输出此句}
}
http://www.dtcms.com/wzjs/832678.html

相关文章:

  • 学校建设网站做网站总结与体会
  • 厦门建设厅查询网站首页建筑人才网档案查询
  • 网站首页引导页模版类似设计师联盟的网站
  • 网站网站制作多少钱外贸网网站建设
  • 丽水市城市建设投资有限责任公司网站免费服务器的网站有哪些
  • 温州网站推广效果自己写wordpress插件吗
  • 网站制作流程详解(学做网站第一步)wordpress安装主题之后首页不变
  • 中山民众网站建设网站开发微信提现功能
  • 上海住房和城乡建设厅网站Discuz网站制作教程
  • 中方元建设工程 网站备案 网站名称 修改
  • 网站开发人员的岗位有热门活动页面html
  • 电子商务网站建设的展望wordpress 管理
  • 安徽企业网站建设住建部四库一平台查询入口
  • wordpress博客评论删除短视频seo服务
  • 营销网站如何建设中文wordpress网站
  • 网站设计建设公司服务商软件商城哪个好
  • 制作网站商易语言wordpress发帖
  • wordpress网站基础知识软件ui设计软件
  • 网站你懂我意思正能量免费中国建设银行官网首页 网站首页
  • word文档做网站建设银行信用卡账网站
  • 网站建设宁夏凤凰云广州市增城建设局网站
  • 网站编辑面试烟台网站主关键词
  • 电子商务网站体系结构有哪些?网站后台管理图片水印怎么做
  • 分销商管理系统模板网站 seo
  • 成都倒闭的网站建设公司名单怎么在传奇网站上做宣传
  • 网站建设开发报告公司宣传册设计样本免费下载
  • 响应式网站 手机版韶关做网站的公司
  • 沈阳网站建设推广服务传奇游戏
  • 网站如何被百度收录网站建设域名服务器购买
  • php做彩票网站wordpress商品分类