172322 2018-2019-1 《Java软件结构与数据结构》实验一报告

  • 课程:《程序设计与数据结构》
  • 班级: 1723
  • 姓名: 张昊然
  • 学号:20172322
  • 实验教师:王志强
  • 助教:张之睿/张师瑜
  • 实验日期:2018年9月30日
  • 必修/选修: 必修

1.实验内容

  • 此处填写实验的具体内容:

实验内容过多,故参考作业:

2.实验过程及结果

过程:

  • 本次实验总共五个提交点。我也分为五个部分来写过程。

    • 第一:因为之前利用链表实现过队列,故这次就直接import了之前的LinkedQueue将需要输入的元素放入链表队列之中后再输出,利用了数组的方法将元素以空格隔开后再放入链表中,最后打印整个链表。
    • 第二:在第一个节点的基础上利用InputStreamReaderBufferedReader读取文件123.txt的数字8和9,并在LinkedQueue中新写入了addInListaddFisrt方法使得可以将元素插入到链表中的第五位和首位,新写入了delete方法删除指定位置的元素。
    • 第三:在第二个节点的基础上在LinkedQueue中写了selectionSort()方法,排序完成后按照要求输出。
    • 第四:利用数组来实现之前链表所实现的第一和第二个节点,但是因为之前实现的队列是利用循环数组来实现的不方便指定位置的插入和删除,故新写了非循环单向数组类myarray,之后的实现均以它为基础,第一部分的实现与链表的实现相似,并且相应的写入了insertInarray方法实现指定位置的插入,delete实现指定位置的删除。
    • 第五:在第四个节点的基础上在myaraay中写入了selectionSort()方法实现排序后按要求输出。

结果:

1.

2.

3.

4.

5.

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

本次实现的问题大多是一些小问题,因为在之前的学习中已经接触了非常多次的链表和数组,对于它们的原理与实现都比较清晰了。

  • 问题1:在做节点一时对于怎样将输入的元素利用空格隔开后再放入队列中产生了疑惑。
  • 问题1解决方案:向王文彬同学求助,他给我提供了
        String[] a = sentence.split(" ");
for (int i =0;i<a.length;i++){
queue.enqueue(a[i]);
}

利用数组将每个元素分开后再放入一一放入队列之中,真是妙呀

  • 问题2:在做节点二时需要将数字二插入首位,但是链表的首插法没有实现过,所以我就在网上找了很多很多的实现方法,结果都是导致整个链表丢失。
  • 问题2解决方案:在被逼急过后决定自己写一个头插法,在经过自己许久的思考和仔细的画图过后写下了以下方法
    public void addFisrt(T element)
{
LinearNode<T> node = new LinearNode<T>(element);
current = head;
node.next = head;
head = node;
count++;
}

然后居然就成功了...成功了......我这个时候就很纠结,为啥我要花一个下午的时间去网上查如何实现,最终却只花了自己十分钟的时间写出了这个方法呢......

  • 问题3:在节点二中从文件中提取元素都非常顺利但是如何将两个元素利用分开然后转化为整形就有了一些困难。
  • 问题3解决方案:又向王文彬同学求助了,他又为我提供了
         int n1 = Integer.parseInt(String.valueOf(lineTxt.charAt(0)));
int n2 = Integer.parseInt(String.valueOf(lineTxt.charAt(2)));

在提取了元素的同时将元素转化为整形,真是厉害。

  • 问题4: 在实现节点四时,在数组中间插入元素一直插不进去,不是插的位置原本的元素没了就是后面的元素全变成了需要插入的元素。
  • 问题4解决方案:幸好这次是王老师在旁边,就直接向王老师求助了,他为我重新讲解了数组插入元素的原理,需要先将后面的元素全部向后移动一位之后再在原本位置插入需要插入的元素。Just like:
    for (int i = elements; i > index-1; i--)
{ array[i+1] = array[i]; }
array[index] = element;

代码托管

其他(感悟、思考等)

感悟

  • 网上的东西不一定是最好的,有的时候自己去思考、去实现比一开始就去网上找需要的东西会好得多,不能有偷懒的思想。

参考资料

172322 2018-2019-1 《Java软件结构与数据结构》实验一报告的更多相关文章

  1. 20172328 2018—2019《Java软件结构与数据结构》第二周学习总结

    20172328 2018-2019<Java软件结构与数据结构>第二周学习总结 概述 Generalization 本周学习了第三章集合概述--栈和第四章链式结构--栈.主要讨论了集合以 ...

  2. 20172302 《Java软件结构与数据结构》实验三:查找与排序实验报告

    课程:<Java软件结构与数据结构> 班级: 1723 姓名: 侯泽洋 学号:20172302 实验教师:王志强老师 实验日期:2018年11月19日 必修/选修: 必修 实验内容 (1) ...

  3. 20172302 《Java软件结构与数据结构》实验二:树实验报告

    课程:<Java软件结构与数据结构> 班级: 1723 姓名: 侯泽洋 学号:20172302 实验教师:王志强老师 实验日期:2018年11月5日 必修/选修: 必修 实验内容 (1)参 ...

  4. 20172302 《Java软件结构与数据结构》实验一:线性结构实验报告

    课程:<Java软件结构与数据结构> 班级: 1723 姓名: 侯泽洋 学号:20172302 实验教师:王志强老师 实验日期:2018年9月26日 必修/选修: 必修 实验内容 (1)链 ...

  5. 20172301 《Java软件结构与数据结构》实验三报告

    20172301 <Java软件结构与数据结构>实验三报告 课程:<Java软件结构与数据结构> 班级: 1723 姓名: 郭恺 学号:20172301 实验教师:王志强老师 ...

  6. 20172301 《Java软件结构与数据结构》实验二报告

    20172301 <Java软件结构与数据结构>实验二报告 课程:<Java软件结构与数据结构> 班级: 1723 姓名: 郭恺 学号:20172301 实验教师:王志强老师 ...

  7. 20172329 2018-2019 《Java软件结构与数据结构》实验三报告

    20172329 2018-2019-2 <Java软件结构与数据结构>实验三报告 课程:<Java软件结构与数据结构> 班级: 1723 姓名: 王文彬 学号:2017232 ...

  8. 20172329 2018-2019-2 《Java软件结构与数据结构》实验二报告

    20172329 2018-2019-2 <Java软件结构与数据结构>实验二报告 课程:<Java软件结构与数据结构> 班级: 1723 姓名: 王文彬 学号:2017232 ...

  9. 20172301 《Java软件结构与数据结构》实验一报告

    20172301 <Java软件结构与数据结构>实验一报告 课程:<Java软件结构与数据结构> 班级: 1723 姓名: 郭恺 学号:20172301 实验教师:王志强老师 ...

随机推荐

  1. ubuntu 如何进行文件、夹删除等操作

    rm [选项] 文件-f, --force 强力删除,不要求确认-i 每删除一个文件或进入一个子目录都要求确认-I 在删除超过三个文件或者递归删除前要求确认-r, -R 递归删除子目录-d, --di ...

  2. Linux(CentOS7)设置自动备份数据库到阿里云OSS

    环境:阿里云服务器CentOS7.4 + MySQL5.6 基本思路: 1.编写shell脚本,备份数据库到指定目录下 2.编写Python脚本,把文件上传到OSS 3.把shell脚本和Python ...

  3. Redis推荐阅读笔记整理

    Herrt灬凌夜    https://www.cnblogs.com/wuyx/archive/2018/03.html 6. Redis_常用5大数据类型简介 5. redis_安装 4. Red ...

  4. laravel Eloquent ORM联合查询出现Class not found,就算在Moel中存在这个类

    今天发现一个坑,在处理Eloquent ORM的联合查询时,一直报错Class 'AdminGroup' not found ,可是我的项目中明明存在这个类,如下 这是我的模型类: 它们的控制器方法: ...

  5. 【ElasticSearch故障处理】OpenJDK 64-Bit Server VM warning

    [故障描述] VM虚拟机安装ElasticSearch集群,有三台Linux,完成安装后,执行启动命令:bin/elasticsearch -d . 运行结果报错: OpenJDK 64-Bit Se ...

  6. Python系列之 迭代器和生成器

    很多Python的程序员都会混淆 迭代器 和 生成器 的概念和作用,分不清到底两个有什么区别.今天我们来好好说一说这两个概念. 迭代器(Iterator) Iterator Pattern Itera ...

  7. PLL各种问题,关于倍频

    原来一直想不通频率为什么可以增加. 一个4M的时钟怎么就可以升高到40M, 现在明白了,4M的时钟并没有被升高, 而是PLL里的VCO这个东西, 这个东西可以产生一定范围的内的任意频率信号, 频率由输 ...

  8. SpringMVC 中,当前台传入多个参数时,可将参数封装成一个bean类

    在实际业务场景中,当前台通过 url 向后台传送多个参数时,可以将参数封装成一个bean类,在bean类中对各个参数进行非空,默认值等的设置. 前台 url ,想后台传送两个参数,userName 和 ...

  9. 安装虚拟机&Linux命令学习

    安装虚拟机&Linux命令学习 基于VirtualBox虚拟机安装Ubuntu 1.下载安装VirtualBox 根据自己电脑(32位操作系统)的实际情况,我在网上找了相应的VirtualBo ...

  10. Caliburn.Micro - Getting Started - Introduction

    Caliburn.Micro Xaml made easy Introduction When my “Build Your Own MVVM Framework” talk was chosen f ...