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

凡科网做网站花多少钱外贸网站建站

凡科网做网站花多少钱,外贸网站建站,免费域名qq空间申请,做网站需要前置审批🎇个人主页:Ice_Sugar_7 🎇所属专栏:Java数据结构 🎇欢迎点赞收藏加关注哦! 实现哈希表 🍉扩容🍉插入🍉获取value🍉源码 🍉扩容 在讲插入之前需要…

🎇个人主页:Ice_Sugar_7
🎇所属专栏:Java数据结构
🎇欢迎点赞收藏加关注哦!

实现哈希表

  • 🍉扩容
  • 🍉插入
  • 🍉获取value
  • 🍉源码

🍉扩容

在讲插入之前需要先了解扩容,因为插入后载荷因子如果超过阈值,那我们就要扩容,即扩容是插入操作的一部分

扩容后,原先哈希表中的元素的哈希地址会改变。之前会发生哈希冲突的元素可能扩容后就不会了
比如数组初始长度为10,hash(key) = key % capacity,那么key为1和key为11的元素会冲突。现在扩容后长度为20,key为11的元素就会到下标为11的位置

扩容的思路为:遍历所有节点,重新计算每个节点的地址,并插入到对应位置

    private void resize() {Node[] newArray = new Node[array.length*2];for(int i = 0;i < array.length;i++) {Node cur = array[i];//遍历链表while(cur != null) {Node tmp = cur.next;  //先保存 cur 的下一个节点,不然头插后会找不到它int newIndex = i % newArray.length;//采用头插法 插入到新数组的 newIndex下标cur.next = newArray[newIndex];newArray[newIndex] = cur;cur = tmp;}}array = newArray;}

🍉插入

插入之前得先检查key是否已经存在,如果已经有了,则只需更新它的value

    public void put(int key, int value) {int hash = key % array.length; //计算地址Node cur = array[hash];while(cur != null) {  //先找一下key是否已经存在,若已经存在,则更新它的value就可以了if(cur.key == key) {cur.value = value;return;}cur = cur.next;}//到这里说明没找到key,那么就创建新节点,然后头插Node node = new Node(key,value);node.next = array[hash];array[hash] = node;size++;if(size*1.0 / array.length > LOAD_FACTOR) {resize();}}

🍉获取value

这个操作很简单,直接上代码:

    public int get(int key) {int hash = key % array.length;Node node = array[hash];while(node != null) {if(node.key == key)return node.value;node = node.next;}return -1;}

🍉源码

源码放在gitee仓库了,详情可看下面链接:
实现哈希表

http://www.dtddedu.com/news/42.html

相关文章:

  • 哪些网站可以做批发衣服太原seo哪家好
  • 新网站建设网站营销与推广
  • 课程网站建设域名解析ip138在线查询
  • 怎么做网站认证谷歌搜索引擎363
  • 大连网站制作姚喜运淘宝seo
  • 保险公司官方网站怎样做市场营销策划
  • 东营市做网站优化长沙网站推广有哪些啊
  • 四川省建设工程质量监理协会网站小程序排名优化
  • 凯里网站制作今日十大热点新闻事件
  • 电子工程网站有哪些官网首页入口百度
  • 移动广告公司网站建设上海seo推广整站
  • 网站建设是否属于技术合同黑马it培训班出来现状
  • 建站工具上市武汉seo工作室
  • 网站开发 怎样做费用结算深圳百度关键词排名
  • 那间公司做网站好厦门百度关键词优化
  • 现在1做啥网站流量大bing搜索引擎入口官网
  • 有人知道做网站吗?买卖网站
  • 网站建设管理风险点如何写软文
  • 怎么做网站二维码网络营销策略ppt
  • 手机640的设计稿做网站搜狗引擎搜索
  • 做网站排行企业网站优化外包
  • 如何在虚拟机中建设网站怎么做电商新手入门
  • 厦门最早做网站的公司百度指数是啥
  • 乐清做网站哪家好百度服务中心人工24小时电话
  • 网站建设新趋势树枝seo
  • 后端开发需要掌握什么技术seo发外链工具
  • 建设工程质量 协会网站百度推广app怎么收费
  • 东城区网站排名seo拉新项目官方一手平台
  • 网站关键词优化哪家正规搜索引擎最新排名
  • 网站增加外链方法长沙百度seo代理