zoukankan      html  css  js  c++  java
  • 20182311 2019-2020-1 《数据结构与面向对象程序设计》实验七报告

    20182311 2019-2020-1 《数据结构与面向对象程序设计》实验七报告

    课程:《程序设计与数据结构》
    班级: 1823
    姓名: 冷冲
    学号:20182311
    实验教师:王志强
    实验日期:2019年10月30日
    必修/选修: 必修

    1.实验内容

    • 定义一个Searching和Sorting类,并在类中实现linearSearch,SelectionSort方法,最后完成测试。要求不少于10个测试用例,提交测试用例设计情况(正常,异常,边界,正序,逆序),用例数据中要包含自己学号的后四位提交运行结果图。
    • 重构你的代码把Sorting.java Searching.java放入 cn.edu.besti.cs1823.(姓名首字母+四位学号) 包中(例如:cn.edu.besti.cs1823.G2301),把测试代码放test包中重新编译,运行代码,提交编译,运行的截图(IDEA,命令行两种)
    • 参考http://www.cnblogs.com/maybe2030/p/4715035.html ,学习各种查找算法并在Searching中补充查找算法并测试,提交运行结果截图。
    • 补充实现课上讲过的排序方法:希尔排序,堆排序,二叉树排序等(至少3个),测试实现的算法(正常,异常,边界)提交运行结果截图(如果编写多个排序算法,即使其中三个排序程序有瑕疵,也可以酌情得满分)
    • 编写Android程序对实现各种查找与排序算法进行测试,提交运行结果截图,推送代码到码云(选做,加分)。

    2. 实验过程及结果

    • 定义一个Searching和Sorting类,并在类中实现linearSearch,SelectionSort方法,最后完成测试。
    • 补充实现课上讲过的排序方法:希尔排序,堆排序,二叉树排序等
    • 参考 ,学习各种查找算法并在Searching中补充
      • 线性查找:遍历数组,找到则返回数组元素下标,未找到返回-1;

      • 二分查找:

        • 折半实现:使用first和last标记所有元素的起始处和结尾处,mid取(first+last)/2,当first<=last时循环,实现每次指向中值的查找。
        • 递归实现:大致代码如下,递归方法需要增加两个形参用来标记递归进行到哪一步了。
        public static Comparable BinarySearch2(Comparable[] data,Comparable target,int first,int last){
                int mid=(first+last)/2;
                if(data[mid].compareTo(target)==0){
                    return mid+1;
                }
                if(data[mid].compareTo(target)>0)
                     return BinarySearch2(data,target,first,mid-1);
                if(data[mid].compareTo(target)>0)
                    return BinarySearch2(data,target,mid+1,last);
                return false;
        }
        
        • 插值查找:二分查找法的改进版,只是将mid的取值方式改进如下:
         mid=first+(target-data[first])/(data[last]-data[first])*(last-first);
        
        • 哈希查找:通过求余算法确定访问元素的下标。
        • 斐波那契查找:获取斐波那契数列,再使用黄金分割算法确定访问元素的下标。
        • 插入排序:利用双重循环和插入,逐渐将整个表从前向后实现有序排列。
        • 折半插入排序:对插入排序的改良,将线性探索改为折半探索
        • 快速排序:根任意元素划分表,再递归的对两个子表进行排序,从而完成一整组的排序。
        • 归并排序:先递归的把表对分成每个子表只含一个元素,再将子表按序合并。
        • 选择、冒泡排序:



    • 重构你代码,放入cn.edu.besti.cs1823.Lc20182311包中重新编译提交编译IDEA,命令行两种运行截图。

    • 编写Android程序对实现各种查找与排序算法进行测试
      安卓的布局真令人头疼,动不动就覆盖。

    3.实验过程中遇到的问题及解决过程

    • 问题1:使用compareto比较两个comparable数组元素出错
    • 问题1解决方案:使用compareTo方法进行两个对象的比较,首先要将类继承comprable接口,这一点做到了。但是下列代码就会报错,因为数组第一行只是声明了一个数组,没有实例化不能使用compareTo方法。
    Comprare[] a=new Comprare[4];
    a[1].comprareTo(a[2]);
    
    • 问题2:为什么使用arrays.sort()方法必须实现Comparable接口?
    • 问题2解决方案:Arrays.sort(Object[] objs)方法的排序机制是,在内部把Object数组里面强制转换为Comparable类型,再调用compareTo()方法进行排序。调用CompareTo()方法需要实现Comparable接口。

    4.参考资料

  • 相关阅读:
    arcgis server 中Web墨卡托投影与WGS-84坐标的转换
    jQuery的鼠标事件总结
    Aps.net中基于bootstrapt图片上传插件的应用
    动态添加div及对应的js、css文件
    jQuery时间格式插件-moment.js的使用
    arcgis地图服务之 identify 服务
    ASP.NET导出word实例
    ArcGIS字段计算器分割字段中的字符串
    正则表达式中的特殊字符
    arcgis for js开发之路径分析
  • 原文地址:https://www.cnblogs.com/lengchong/p/11870639.html
Copyright © 2011-2022 走看看