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

深圳工程造价信息网seo推广关键词公司

深圳工程造价信息网,seo推广关键词公司,做智能网站平台,js网站繁体平日里面经常使用map这种数据结构,令人称奇的是他的访问速度为什么那么快?为什么可以通过key以接近O(1)的速度查找? 一、基础数据结构特点分析 1.1数组 查找的时间复杂度为O(1) 插入时间复杂度为O(n) 1.2链表 查找的时间复杂度为O(n) 插…

平日里面经常使用map这种数据结构,令人称奇的是他的访问速度为什么那么快?为什么可以通过key以接近O(1)的速度查找?

一、基础数据结构特点分析

1.1数组

查找的时间复杂度为O(1)

插入时间复杂度为O(n)

1.2链表

查找的时间复杂度为O(n)

插入时间复杂度为O(1)

1.3红黑树

一种平衡树,能以较低的时间复杂度进行搜索、添加和查找操作O(logn)

可以优化节点查找速度

所以如果我们能找到一种,通过数组进行范围筛选,通过链表对数据进行增删的数据结构来存储数据,那么就能够获得较快的查询速率

二、hashMap基本实现原理

2.1hash过程

将这个数据节点进行hasCode操作,获取一个hash值

2.2hash定位

hash值对数组长度取模,获取一个模值,相同模值的数据节点挂载在同一个链表上

2.3查找

获取数据的时候就将该key转成hash,计算其模值,在对应的链表上面进行顺序查找

2.4hash冲突过多的优化

什么是hash冲突?:不同的key算出了相同的hash

解决方案1(Java采用)——链地址法:相同的hash值转到一个链表,链表长度大于8转换成红黑树,红黑树规模小于6退化成链表

特点:

(1)要减少hash冲突需要很大的散列,利用率不够大

(2)默认大小为16,超过就扩充一倍

解决方案2(Python采用)——开放寻址法:算出了相同的hash值就继续往下遍历寻找第一个找到的空hash值

特点:

(1)适用于负载不大的散列,负载过大会长时间找不到空hash

(2)负载超过一定阙值就扩容,而不是满了再扩容

http://www.hrbkazy.com/news/34272.html

相关文章:

  • 如何自己开一个网站收录优美图片topit
  • 广东深圳福田区沈阳百度seo
  • 浙江平安建设网站扬州seo推广
  • 专业优定软件网站建设真正免费的网站建站
  • 深圳做营销网站公司seo是指什么岗位
  • 中铁建设集团有限公司中南分公司东莞优化网站制作
  • 关于公路建设的网站网站建站价格
  • 杭州滨江网站开发sem推广软件
  • 关于政府网站群建设的咨询函长春网站开发
  • 网站怎么弄三级域名seo优化是怎么回事呢
  • 百度做网站哪里可以学百度账户安全中心
  • 网站建设价格热线北京百度总部电话
  • 坂田做网站多少钱网站网络营销公司
  • 松原做网站平台营销型网站建设目标
  • 南山做网站多少钱seo网站优化培训找哪些
  • asp.net 做网站好吗怎么上百度搜索
  • 江宁区建设局网站新东方英语培训机构官网
  • 双语网站怎么做的优化大师官方下载
  • 封面免费制作网站许昌seo推广
  • 哪有网站建设的网站策划
  • 石家庄新闻媒体求助热线电话全能优化大师
  • 网站开发网站设计北大青鸟职业技术学院简介
  • 同城招聘网站自助建站网络营销的方法包括哪些
  • 修网络seo排名方案
  • 重庆网站建设招标百度怎么推广自己的网站
  • 做破解的网站四川网站seo
  • 江都建设银行网站网络运营团队
  • 自建房设计网站推荐百度工具seo
  • 唐山网站建设正规公司网站搭建平台
  • 用区块链来做网站网站关键词优化排名公司