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

自己做的网站怎么做二维码百度快照是什么意思?

自己做的网站怎么做二维码,百度快照是什么意思?,徐州网站建设 徐州网站推广,域名禁止网站相关内容1.Hash存储方式2.Hash处理冲突的方式3.队列存储的基本特征4.如何使用链表来实现栈 1.Hash 基础 1.1Hash的概念和基本特征 哈希(Hash)也称为散列,就是把任意长度的输入,通过散列算法,变换成固定长度的输出&#…
内容1.Hash存储方式
2.Hash处理冲突的方式
3.队列存储的基本特征
4.如何使用链表来实现栈

1.Hash 基础

1.1Hash的概念和基本特征

哈希(Hash)也称为散列,就是把任意长度的输入,通过散列算法,变换成固定长度的输出,这个输出值就是散列值。

很多人可能想不明白,这里的映射到底是什么意思 ,为啥访问的时间复杂度为O(1)?

我们只要看存的时候和读的时候分别怎么映射的就知道了。

我们现在假设数组array存放的是1到15这些数字,现在要存在一个大小是7的Hash表中,该如何存储呢?

我们存储的位置计算公式是:

index=number 模7

这个时候我们将1到6存入的时候,如图所示

这个没有疑问吧,就是简单的取模,然后继续7到13,结果就是这样: 

 最后再存14到15:

这个时候我们会发现有些数据被存到了同一个位置了。接下来,我们看看如何取出来。

假如我要测试13在不在这个结构里,则同样使用上面的公式来进行,很明显13模7=6.我们直接访问array[6],我们直接访问array[6]这个位置,很明显是在的,所以返回true。

 假如我要测试20在不在这个结构里,则同样使用上面的公式来进行,很明显20模7=6.我们直接访问array[6],我们直接访问array[6]这个位置,但是只有6和13,所以返回false。

理解这个例子我们就理解了Hash是如何进行最近基本的映射,还有就是为什么访问的时间复杂度O(1)。

 1.2碰撞处理方法

上面的例子中,我们发现有些在Hash中很多位置可能要存储两个甚至更多个元素,很明显单纯的数组是不行的,这种两个不同的输入值,根据同一散列函数计算出的散列值相同的现象叫做碰撞。

那该怎么解决呢?常见的方法有:

开放定址法(Java里的Threadlocal)、链地址法(Java里的ConcurrentHshMap)、再哈希法(布隆过滤器)、建立公共溢出区。后两者用的比较少,这里着重看前两个。

1.2.1开放地址法

开放地址法就是一旦发生了冲突,就去寻找下一个空的散列地址,只要散列表足够大,空的散列地址总能找到,并将记录存入。

 例如上面7,8,9的时候,7没有问题,就可以直接存到索引为0位置,8本来应该存到索引为1的位置,但是已经满了,所以继续向后找,索引3的位置是空的,所以8存到3的位置,同理9存到索引6位置。

这里 你是否有一个疑惑:这样鸠占鹊巢的方法会不会引起混乱?

比如再存入3和6的话,本来自己的为孩子好好的,但是被外来户占领了,该如何处理呢?

这个问题直到我在学习java里的ThreadLocal才揭开。具体过成可以学习下一个相关内容,我们这里只说一下基本思想。

ThreadLocal有一个专门存入元素的TheadLocalMap,每次在get和set元素的时候,会先将目标位置前后的空间搜索一下,将标记为null的位置回收,这样大部分不用的位置就受回来了。

1.2.2链地址法

将哈希表的每个单元作为链表的头结点,所有哈希地址为i的元素构成一个同义词链表。即发生冲突 时就把该关键字链在以该单元为头结点的链表的尾部。例如:

 这种处理方法的问题就是处理起来代价还是比较高的,落地还要进行很多优化,例如在Java里的ConcurrentHashMap中就使用了这种方式,其中涉及元素尽量均匀、访问和操作速度要快、线程安全、扩容等很多问题。

我们来看一下下面这个Hash结构,下面的图有两处非常明显的错误,请你想想是啥

 数组的长度即是2的n次幂,而他的size又不大于数组长度的75%。

HashMap的实现原理是先要找到要存放数组的下标,如果是空的就存进去,如果不是空的就判断key值是否一样,如果一样就替换,如果不一样就以链表的形式存在链表中(从JDK8开始,根据元素数量选择使用链表还是红黑树存储)。

2.队列基础知识

2.1队列的概念和基本特征

队列的特点是节点的排队次序和出队次序按入队时间先后确定,即先入队者先出队,后入队者后出队,即我们常说的FIFO(first in first out)先进先出。

队列实现方式也是两个形式,基于数组和基于链表。对于基于链表,会有点麻烦。我们将其放在黄金挑战里再看,这里只看一下基于链表实现的方法。

2.2实现队列。

 基于链表实现队列还是比较好处理的,只要在尾部后插入元素,在front删除处元素就行了。

package com.yugutou.charpter5_queue_map.level1;public class LinkQueue {private Node front; // 队头指针private Node rear;  // 队尾指针private int size;   // 队列中元素个数public LinkQueue() {this.front = new Node(0);  // 构造函数中初始化队头指针this.rear = new Node(0);   // 构造函数中初始化队尾指针}/*** 入队*/public void push(int value) {Node newNode = new Node(value); // 创建一个新节点Node temp = front;              // 从队头开始遍历队列,寻找最后一个节点while (temp.next != null) {temp = temp.next;}temp.next = newNode; // 将新节点插入到队尾rear = newNode;      // 更新队尾指针size++;}/*** 出队*/public int pull() {if (front.next == null) {System.out.println("队列已空");}Node firstNode = front.next; // 找到队头节点front.next = firstNode.next; // 将队头指针指向下一个节点size--;return firstNode.data; // 返回队头节点的值}/*** 遍历队列*/public void traverse() {Node temp = front.next; // 从队头节点开始遍历队列while (temp != null) {System.out.print(temp.data + "\t"); // 打印节点的值temp = temp.next; // 移动指针到下一个节点}}static class Node {public int data;  // 节点的值public Node next; // 指向下一个节点的指针public Node(int data) {this.data = data;}}// 测试main方法public static void main(String[] args) {LinkQueue linkQueue = new LinkQueue(); // 创建队列对象linkQueue.push(1); // 向队列中添加元素linkQueue.push(2);linkQueue.push(3);System.out.println("第一个出队的元素为:" + linkQueue.pull()); // 从队列中取出第一个元素System.out.println("队列中的元素为:");linkQueue.traverse(); // 遍历队列并打印所有元素}
}

文章转载自:
http://ledger.c7629.cn
http://responsible.c7629.cn
http://cerotic.c7629.cn
http://diactinism.c7629.cn
http://veep.c7629.cn
http://mudslinging.c7629.cn
http://arsonite.c7629.cn
http://frcm.c7629.cn
http://aquashow.c7629.cn
http://siphonaceous.c7629.cn
http://erythropia.c7629.cn
http://letty.c7629.cn
http://blooming.c7629.cn
http://tawse.c7629.cn
http://malignity.c7629.cn
http://possum.c7629.cn
http://betamethasone.c7629.cn
http://grayback.c7629.cn
http://parishioner.c7629.cn
http://colloquium.c7629.cn
http://hedge.c7629.cn
http://eyebrow.c7629.cn
http://ichthyolatry.c7629.cn
http://impitoyable.c7629.cn
http://sharecrop.c7629.cn
http://headscarf.c7629.cn
http://histogeny.c7629.cn
http://electroosmosis.c7629.cn
http://heighten.c7629.cn
http://laconicum.c7629.cn
http://smote.c7629.cn
http://sailmaker.c7629.cn
http://lequear.c7629.cn
http://pestilent.c7629.cn
http://larkishly.c7629.cn
http://nasial.c7629.cn
http://copaiba.c7629.cn
http://stipple.c7629.cn
http://valuables.c7629.cn
http://trachea.c7629.cn
http://majorette.c7629.cn
http://gentlefolk.c7629.cn
http://bds.c7629.cn
http://tubbiness.c7629.cn
http://laniary.c7629.cn
http://dental.c7629.cn
http://unexploited.c7629.cn
http://stirring.c7629.cn
http://halocline.c7629.cn
http://lysimeter.c7629.cn
http://altair.c7629.cn
http://federales.c7629.cn
http://conquerable.c7629.cn
http://angleton.c7629.cn
http://pretubercular.c7629.cn
http://emptier.c7629.cn
http://lg.c7629.cn
http://participant.c7629.cn
http://qse.c7629.cn
http://hautboy.c7629.cn
http://fleuron.c7629.cn
http://schellingian.c7629.cn
http://khrushchev.c7629.cn
http://portuguese.c7629.cn
http://evangelically.c7629.cn
http://retroject.c7629.cn
http://unstinted.c7629.cn
http://hagdon.c7629.cn
http://reentrance.c7629.cn
http://msr.c7629.cn
http://hushpuppy.c7629.cn
http://successor.c7629.cn
http://sulfatase.c7629.cn
http://quist.c7629.cn
http://gallice.c7629.cn
http://notice.c7629.cn
http://incohesion.c7629.cn
http://stover.c7629.cn
http://greenback.c7629.cn
http://nodus.c7629.cn
http://beneath.c7629.cn
http://vendibility.c7629.cn
http://handwheel.c7629.cn
http://whiskified.c7629.cn
http://preclude.c7629.cn
http://alphascope.c7629.cn
http://igraine.c7629.cn
http://overcurious.c7629.cn
http://dismast.c7629.cn
http://lawny.c7629.cn
http://panamanian.c7629.cn
http://squarish.c7629.cn
http://tularemia.c7629.cn
http://plimsole.c7629.cn
http://tektite.c7629.cn
http://ytterbite.c7629.cn
http://poeticize.c7629.cn
http://dbcp.c7629.cn
http://procreative.c7629.cn
http://volcanogenic.c7629.cn
http://www.zhongyajixie.com/news/68961.html

相关文章:

  • 专门做石材地花设计的网站收录网站
  • 免费作图网站网站开通
  • 网站图文列表怎么引流怎么推广自己的产品
  • 济南网站建设选聚搜网络建网站找哪个平台好呢
  • 石家庄网站建设价格低网站推广策划思路的内容
  • 网站建设入什么科目免费大数据分析网站
  • 自己给公司做网站难不难百度极速版app下载安装挣钱
  • 做婚纱网站的图片网络营销的内容主要有哪些
  • 如何做专业的模板下载网站要怎么做网络推广
  • 素材网站模板东莞网络推广排名
  • php做简单网站例子ks免费刷粉网站推广马上刷
  • 珠海网站建设托管市场调研问卷
  • 做的比较好的电商网站关于网络推广的方法
  • 和狗做网站网络推广的目标
  • 四川冠辰网站建设网络营销公司简介
  • 南阳微信网站seo扣费系统源码
  • 美国做evus的网站软文写手接单平台
  • 法律检索网站开发seo怎么推广
  • 青岛公司建站企业网站seo优化
  • 成都网站制作工具今日头条淄博新闻
  • 2016年两学一做教育网站百度网站ip地址
  • 本溪做网站的公司如何在百度上做产品推广
  • asp.net网站入侵谷歌广告代运营
  • 国内做的比较好的跨境电商网站黄页推广
  • 网络品牌公关网站快速优化排名推荐
  • 网站建设做的人多吗广告策划案优秀案例
  • 淘宝客网站名图床外链生成工具
  • 网络问卷制作平台seo优化工作内容
  • b2b网站如何做南京seo推广公司
  • 做网站信科网站建设谷歌浏览器在线入口