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

电子电路自学网站wordpress博客蜘蛛统计

电子电路自学网站,wordpress博客蜘蛛统计,峰峰信息港,区网站制作1.Hash基础 #xff08;1#xff09;基础 哈希也称为散列#xff0c;通过算法变成固定长度的输出值#xff0c;存入对应的位置 例如这个算法为取模算法#xff0c;indexnumber 模 7 存入1到15 #xff08;2#xff09;碰撞处理 当多个元素映射到同一位置上时就产生…1.Hash基础 1基础 哈希也称为散列通过算法变成固定长度的输出值存入对应的位置 例如这个算法为取模算法indexnumber 模 7 存入1到15 2碰撞处理 当多个元素映射到同一位置上时就产生了碰撞 哈希碰撞处理是在使用哈希函数时不同的键可能映射到相同的哈希值哈希冲突时的解决方法。哈希碰撞处理是为了确保不同的键可以在哈希表中正确存储和检索从而维护哈希表的性能和正确性。 以下是几种常见的哈希碰撞处理方法 链地址法Chaining 这是一种常见的方法通过在哈希桶位置上维护一个链表或其他数据结构将发生冲突的键值对添加到链表中。在查找或删除操作时遍历链表来找到对应的键值对。 开放定址法Open Addressing 在这种方法中当发生冲突时会顺序地在哈希表中的其他位置寻找空闲的位置来存储键值对。这包括线性探测、二次探测、双重哈希等策略。 再哈希法Rehashing 当发生冲突时计算另一个哈希函数然后将键值对存储在新的哈希桶位置上。这可以有效地减少冲突。 建立一个“桶”的链表 这是一种类似于链地址法的方法但不是在每个哈希桶位置上维护一个链表而是在发生冲突的哈希桶位置上维护一个链表。 完全二叉树 将键值对按照哈希值顺序存储在完全二叉树的节点上。这种方法在特定情况下可以提供较好的性能。 开放定址法 开放定址法的主要思想是当发生哈希冲突时不仅仅将数据存储在哈希桶中而是根据某种算法找到一个不冲突的位置将数据存储在那里。这就需要一个探测序列probing sequence它是一系列指示位置的步骤用于寻找下一个可用的位置。 常见的开放定址法包括 线性探测Linear Probing 在发生冲突时按顺序检查下一个位置直到找到一个空闲位置为止。 二次探测Quadratic Probing 在发生冲突时按照某个步长的平方逐渐增加位置直到找到一个空闲位置为止。 双重散列Double Hashing 在发生冲突时使用第二个哈希函数计算一个步长然后在哈希表中逐渐增加位置直到找到一个空闲位置为止。 开放定址法的优点是它对于内存的利用更有效因为数据存储在数组中没有额外的指针。然而它在负载因子高时可能会导致聚集现象clustering即一些位置上会有很多连续的元素而其他位置则很少使用。这可能会降低性能。 链地址法 链地址法Chaining是一种哈希表解决哈希冲突的方法之一。在哈希表中不同的键可能会映射到相同的哈希桶位置这就产生了哈希冲突。链地址法通过在每个哈希桶位置上维护一个链表或其他数据结构来处理这种冲突。 具体来说当发生哈希冲突时链地址法将冲突的键值对添加到哈希桶位置对应的链表中。每个链表节点包含一个键值对。当需要插入、查找或删除一个键值对时先计算哈希值找到对应的哈希桶位置然后在该位置的链表中进行操作。 以下是链地址法的基本步骤 插入 计算键的哈希值找到对应的哈希桶位置。如果该位置为空则在该位置插入键值对。如果该位置已经有其他键值对存在即发生冲突则在链表中继续插入新的键值对。 查找 计算键的哈希值找到对应的哈希桶位置。然后遍历链表查找包含该键的节点。 删除 计算键的哈希值找到对应的哈希桶位置。然后遍历链表找到包含该键的节点并进行删除操作。 链地址法的优点是它相对简单可以有效地解决哈希冲突。然而当哈希冲突较多时链表可能会变得较长导致操作的时间复杂度增加。为了保持哈希表的高效性能需要根据数据分布情况来选择合适的哈希函数并根据情况动态调整哈希桶的数量。另外当链表过长时可以考虑使用更高效的数据结构如红黑树来替代链表以提高查找效率。 2.队列基础 FIFO先进先出的线性表 基于链表实现 尾插头删 public class MyLinkQueue {static class Node {public int data;public Node next;public Node(int data) {this.data data;}}private Node front;private Node rear;private int size;//无参构造初始化public MyLinkQueue() {this.front null;this.rear null;}public boolean isEmpty() {return front null;}//尾插public void push(int data){Node node new Node(data);if (isEmpty()){front node;rear node;}else{rear.next node;rear node;}size;}//头删public int pop(){if (isEmpty()){throw new EmptyStackException();}int res front.data;front front.next;size--;return res;}public int size(){return size;}public void traverse(){Node t front;while(t!null){System.out.println(t.data);t t.next;}}public static void main(String[] args) {MyLinkQueue queue new MyLinkQueue();queue.push(10);queue.push(20);queue.push(30);System.out.println(Queue elements:);queue.traverse(); // Output: 10 20 30System.out.println(Dequeued element: queue.pop()); // Output: 10System.out.println(Queue size: queue.size()); // Output: 2queue.push(40);queue.push(50);System.out.println(Queue elements:);queue.traverse(); // Output: 20 30 40 50System.out.println(Queue size: queue.size()); // Output: 4}}
http://www.hkea.cn/news/14419589/

相关文章:

  • 中小企业做网站网站建设策划公司
  • 英德市网站建设Wordpress如何接入visa支付
  • 济南网站优化推广php 可以自己做网站吗
  • 郎溪网站建设手机上网站用建设工具
  • 怎么健手机网站站长工具视频
  • 杭州做网站哪个公司好v电影主题 wordpress
  • 仿win8 html5微网站纯手工代码建立网站 wordpress
  • 四川和住房城乡建设厅网站首页网站建设h5 招聘
  • 图片制作软件下载泉州seo搜索优化合作
  • 深圳专业app网站开发荣耀手机商城官方网站荣耀60pro
  • 自己创造网站平台软件企业网站模板
  • 公司建设网站产生哪些费用网站定制功能
  • 网站服务器租赁哪家好php做网站基本流程
  • 网站建设与维护网页微博怎么进超话
  • php网站开发技术文档网页html模板代码
  • 浙江省建设部网站网站开发技术选择
  • 烟台市做网站的价格陕西网站seo
  • 做全景图的网站上海企业seo
  • 自己做的网站如何让百度搜索泰安58同城
  • 重庆网站建设公司排名企业形象vi设计案例分析
  • 企业网站seo优化方案东昌府区网站建设公司
  • php商场网站开发经验国家信息公示网查营业执照
  • 大兴安岭建设局网站成都网站建设平台
  • 长沙医院网站建设wordpress后台添加菜单
  • 专业网站设计制作改版成都装修公司有哪些
  • 百度给公司做网站效果咋样如何做网上销售网站
  • 把网站做成微信小程序定制制作网站设计
  • 网站建设的实验的结论个人网页设计风格分析
  • 做网站美工赚钱吗官网网页设计说明
  • 网站建设发布平台宁波职业能力建设网