20172319 2018.10.19 《Java程序设计教程》第7周课堂实践

  • 课程:《程序设计与数据结构》
  • 班级:1723
  • 学生:唐才铭
  • 学号:20172319
  • 指导老师:王志强
  • 日期:2018.10.19
  • 必修/选修:必修

目录


测试内容

  • 三种查找算法练习:
  • 给定关键字序列:11,78,10,1,3,2,4,21,试分别用顺序查找折半查找散列查找 (用线性探查法和链地址法)来实现查找。试画出它们的对应存储形式(顺序查找的顺序表,二分查找的顺序表,两种散列查找的散列表),并求出每一种查找的成功平均查找长度。其中,散列函数H(k) = k%11。
    (本次作业6分,每种算法2分,包括画出存储形式和ASL的计算。)

测试要求

  • 完成蓝墨云班课上的三种查找算法练习任务;并截图(类代码,测试代码,运行结果代码)发送至蓝墨云

  • 返回目录


实验步骤

需求分析

  1. 需要了解、掌握与三种查找相关的知识。
  2. 需要了解、掌握散列查找在发生冲突时的解决方法。
  3. 了解ASL是什么?

相关知识

  • 顺序查找折半查找ASL 此前在第五周学习总结第6周课堂实践中阐述过,这里不再做多余的叙述。

    散列查找:

  • 哈希表(Hash table,也叫散列表),根据关键码值(Key value)而直接进行访问的数据结构。即通过将关键码值映射到表中的一个位置来访问记录,以加快查找的速度。 。 映射函数称为散列函数 , 存放记录的数组称为 散列表
  • 例如:
  • 散列函数为:H(key)= key mod p (p = 11)
  • 对于元素: 17,21,41,38,25。
  • 可通过散列函数来确定其在表中的位置,如对于元素25,H(25)= 25%11 = 3,即其在表中处于第3位。
  • 索引 0 1 2 3 4 5 6 7 8 9 10 11 12
    元素 25 38 17 41 21
  • 而有些时候会发生这样一种情况:H(key1)= H(key2),key1≠key2。
  • 即在表中发生了冲突 ,这是不可避免的。
  • 介绍几个与其相关的因素:
  • 装填因子(Loading Factor):设散列表空间大小为m,填入表中元素个数是n,则称a=n/m为散列表的填装因子,一般情况下0.6<a<0.9为宜,a越大越有可能发生冲突。
  • p:一般为素数,设散列表空间大小为n,则1.1n<p<1.7n为宜,这样可以尽可能避免发生冲突。

    处理冲突的几种方法

  • 举例:在长度为12的哈希表中已填有关键字分别为17,60,29的记录,(哈希函数H(key)= key MOD 11),现有第四个记录,其关键字为38,由哈希函数得到哈希地址为5,发生冲突。
  • 索引 0 1 2 3 4 5 6 7 8 9 10
    元素 60 17 29

开发地址法:给元素换个位置。

  • 一旦产生冲突(该地址已有其他元素),就按照某种规则去寻找另一个空地址。
  • 若发生了第i 次冲突,试探的下一个地址将增加d
  • h (key) = (h(key)+ d ) mod TableSize (1< i < TableSize )
  • d 决定了不同的解决冲突方案:

    线性探测法:
  • d = i
  • 以增量序列1,2,3 …… (TableSize - 1)循环试探下一个存储地址。
  • 索引 0 1 2 3 4 5 6 7 8 9 10
    元素 60 17 29 38
    二次探测法:
  • d = i 2
  • 以增量序列1 2 ,-1 2 ,2 2,-2 2 ,3 2 ,-3 2 …… q 2 ,-q 2 循环试探下一个存储地址;q≦【TableSize/2】。
  • 索引 0 1 2 3 4 5 6 7 8 9 10
    元素 38 60 17 29
    伪随机探测再散列:
  • d = 伪随机数序列
  • 以伪随机数序列循环试探下一个存储地址。
  • 索引 0 1 2 3 4 5 6 7 8 9 10
    元素 38 60 17 29

链地址法:

  • 开发地址法利用的是表中的剩余空间,如果空间不足,那其将无法处理冲突也无法插入数据,因此此刻需要装填因子≧1。
  • 原理:遇到冲突时,会在原地址新建一个空间,然后以链表节点的形式插入到该空间里。

  • 索引 元素
    0
    1
    2
    3
    4
    5 60 38
    6 17
    7 29
    8
    9
    10
  • 返回目录


实现及解释

  • 关键字序列:11,78,10,1,3,2,4,21。
  • 散列函数: H(k) = k%11。

    线性查找:

  • 索引 0 1 2 3 4 5 6 7
    元素 11 78 10 1 3 2 4 21
    查找次数 1 2 3 4 5 6 7 8
  • ASL = (1 +2 +3 +4 +5 +6 +7 +8)/ 8 = 4.5

    折半查找:

  • 索引 0 1 2 3 4 5 6 7
    元素 11 78 10 1 3 2 4 21
  • 索引 0 1 2 3 4 5 6 7
    元素 1 2 3 4 10 11 21 78
    查找次数 3 2 3 1 3 2 3 4
  • 因为所查找的元素为偶数,所以中值元素为4或10,无论是4还是10,不影响查找的结果。
  • 这里把4当成中值,判定树如下:
  • ASL = (1x1 + 2x2 + 4x3 + 1x4) / 8 = 2.625

散列查找:

  • 开发地址法:
  • 索引 0 1 2 3 4 5 6 7 8 9 10
    元素 11 78 1 3 2 4 21 10
    查找次数 1 1 2 1 3 2 8 1
  • ASL = (1 + 1 + 2 + 1 + 3 + 2 + 8 + 1 ) / 8 = 2.375

  • 链地址法:

  • 查找次数(头) 查找次数(节点) 索引 元素
    1 0 11
    1 2 1 78 1
    1 2 2
    1 3 3
    1 4 4
    5
    6
    7
    8
    9
    1 2 10 10 21
  • ASL = (6x1 + 2x2)/8 = 1.25

  • 返回目录


错误分析

已提交至蓝墨云上的错误:

  1. 除余错误:21%11=9.。。。٩(º﹃º٩)
  2. 索引标识错误。
  3. 查找错误:在开发地址中先放置好相应元素,再对有冲突元素进行处理;如当11、78、10处在了其相应位置后,对冲突元素1不做处理,直接放3,接着对冲突元素2不做处理,直接放4.

参考资料

20172319 2018.10.19《Java程序设计教程》第7周课堂实践(补写博客)的更多相关文章

  1. 《Java程序设计》第12周课堂实践总结

    <Java程序设计>第12周课堂实践总结 实践一 教材代码检查-p98 要求 修改教材P98 Score2.java, 让执行结果数组填充是自己的学号: 提交在IDEA或命令行中运行结查截 ...

  2. 《Java程序设计》第15周课堂实践总结

    <Java程序设计>第15周课堂实践总结 实践一 教材代码检查-p242 要求 在IDEA中或命令行中运行P242 StackTraceDemo2.java 代码运行结果和教材一致吗?为什 ...

  3. 20155233 《Java程序设计》 第十一周课堂练习总结

    20155233 <Java程序设计> 第十一周课堂练习总结 测试题目 1.修改教材P74 一行代码 NineNineTable.java, 让执行结果是个三角形: 提交在IDEA或命令行 ...

  4. 20175316盛茂淞 《java程序设计》第三周课堂测试错题总结

    20175316盛茂淞 <java程序设计>第三周课堂测试错题总结 出现问题 错题总结 题目1 在Ubuntu中用自己的有位学号建一个文件,教材p87 Example4_15 1. 修改代 ...

  5. 20155233 《Java程序设计》 第十三周课堂练习总结

    20155233 <Java程序设计>第十三周课堂练习总结 测试题目 测试1 在IDEA中对P145 MathTool.java 使用JUnit进行单元测试,测试用例不少于三个,要包含正常 ...

  6. 最近准备把安卓和java的知识再回顾一遍,顺便会写博客上!千变万化还都是源于基础,打扎实基础

    最近准备把安卓和java的知识再回顾一遍,顺便会写博客上!千变万化还都是源于基础,打扎实基础,加油吧 距离去北京还有23天

  7. 20172319 2018.10.12《Java程序设计教程》第6周课堂实践(补写博客)

    20172319 2018.10.12 <Java程序设计教程>第6周课堂测验 课程:<程序设计与数据结构> 班级:1723 学生:唐才铭 学号:20172319 指导老师:王 ...

  8. 20172319 2018.04.11 《Java程序设计教程》第7周课堂测验(补写博客)

    20172319 2018.04.11 <Java程序设计教程>第7周课堂测验 课程:<程序设计与数据结构> 班级:1723 学生:唐才铭 学号:20172319 指导老师:王 ...

  9. 20145209刘一阳《JAVA程序设计》第八周课堂测试

    第八周课堂测试 1.下面代码中共有(C)个线程? public class ThreadTest { public static void main(String args[]){ MyThread ...

随机推荐

  1. windows环境用python修改环境变量的注意点(含代码)

    1.部分环境变量字段需要保留原来的值,只是做添加,不可以替换 2.Path和PATH对于python来说是一样的,也就是说存在名为Path的环境变量时,添加PATH的环境变量,会覆盖原有的Path环境 ...

  2. c# 界面自适应大小

    采用在窗体事件SizeChanged里面代码控制大小和位置,达到自动适应窗体大小,这样做调整起来方便. private void FrmMain_SizeChanged(object sender, ...

  3. zabbix系列(四)Zabbix3.0.4添加对Nginx服务的监控

    Zabbix3.0.4添加对Nginx服务的监控 通过Nginx的http_stub_status_module模块提供的状态信息来监控,所以在Agent端需要配置Nginx状态获取的脚本,和添加ke ...

  4. nagios系列(三)之nagios被动监控模式之添加系统负载load、swap、磁盘iostat及memory内存监控详解

    环境: nagios server:192.168.8.42 host_name:node4.chinasoft.com nagios client:192.168.8.41 host_name:no ...

  5. Maven介绍及安装与配置

    一.Maven的作用 在开发中,为了保证编译通过,我们会到处去寻找jar包,当编译通过了,运行的时候,却发现"ClassNotFoundException",我们想到的是,难道还差 ...

  6. python读取两个csv文件数据,进行查找匹配出现次数

    现有需求 表1 表2 需要拿表1中的编码去表2中的门票编码列匹配,统计出现的次数,由于表2编码列是区域间,而且列不是固定的,代码如下 #encoding:utf-8 ##导入两个CSV进行比对 imp ...

  7. 【转载】linux下升级npm以及node

    原文:http://blog.csdn.net/qq_16339527/article/details/73008708 npm升级 废话不多说,直接讲步骤.先从容易的开始,升级npm. npm这款包 ...

  8. locust的安装与使用

    Contents Locust这一款开源性能测试工具.然而,当前在网络上针对Locust的教程极少,不管是中文还是英文,基本都是介绍安装方法和简单的测试案例演示,但对于较复杂测试场景的案例演示却基本没 ...

  9. 判断上学和放假的demo

    var today = new Date(); var xq = today.getDay(); var Now = today.getHours(); if (xq >= 1 &&am ...

  10. DNS java

    https://www.cnblogs.com/549294286/p/5307316.html https://www.cnblogs.com/crazyacking/p/5672032.html