172322 2018-2019-1 《Java软件结构与数据结构》实验一报告
172322 2018-2019-1 《Java软件结构与数据结构》实验一报告
- 课程:《程序设计与数据结构》
- 班级: 1723
- 姓名: 张昊然
- 学号:20172322
- 实验教师:王志强
- 助教:张之睿/张师瑜
- 实验日期:2018年9月30日
- 必修/选修: 必修
1.实验内容
- 此处填写实验的具体内容:
实验内容过多,故参考作业:
2.实验过程及结果
过程:
- 本次实验总共五个提交点。我也分为五个部分来写过程。
- 第一:因为之前利用链表实现过队列,故这次就直接
import了之前的LinkedQueue将需要输入的元素放入链表队列之中后再输出,利用了数组的方法将元素以空格隔开后再放入链表中,最后打印整个链表。 - 第二:在第一个节点的基础上利用
InputStreamReader、BufferedReader读取文件123.txt的数字8和9,并在LinkedQueue中新写入了addInList和addFisrt方法使得可以将元素插入到链表中的第五位和首位,新写入了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软件结构与数据结构》实验一报告的更多相关文章
- 20172328 2018—2019《Java软件结构与数据结构》第二周学习总结
20172328 2018-2019<Java软件结构与数据结构>第二周学习总结 概述 Generalization 本周学习了第三章集合概述--栈和第四章链式结构--栈.主要讨论了集合以 ...
- 20172302 《Java软件结构与数据结构》实验三:查找与排序实验报告
课程:<Java软件结构与数据结构> 班级: 1723 姓名: 侯泽洋 学号:20172302 实验教师:王志强老师 实验日期:2018年11月19日 必修/选修: 必修 实验内容 (1) ...
- 20172302 《Java软件结构与数据结构》实验二:树实验报告
课程:<Java软件结构与数据结构> 班级: 1723 姓名: 侯泽洋 学号:20172302 实验教师:王志强老师 实验日期:2018年11月5日 必修/选修: 必修 实验内容 (1)参 ...
- 20172302 《Java软件结构与数据结构》实验一:线性结构实验报告
课程:<Java软件结构与数据结构> 班级: 1723 姓名: 侯泽洋 学号:20172302 实验教师:王志强老师 实验日期:2018年9月26日 必修/选修: 必修 实验内容 (1)链 ...
- 20172301 《Java软件结构与数据结构》实验三报告
20172301 <Java软件结构与数据结构>实验三报告 课程:<Java软件结构与数据结构> 班级: 1723 姓名: 郭恺 学号:20172301 实验教师:王志强老师 ...
- 20172301 《Java软件结构与数据结构》实验二报告
20172301 <Java软件结构与数据结构>实验二报告 课程:<Java软件结构与数据结构> 班级: 1723 姓名: 郭恺 学号:20172301 实验教师:王志强老师 ...
- 20172329 2018-2019 《Java软件结构与数据结构》实验三报告
20172329 2018-2019-2 <Java软件结构与数据结构>实验三报告 课程:<Java软件结构与数据结构> 班级: 1723 姓名: 王文彬 学号:2017232 ...
- 20172329 2018-2019-2 《Java软件结构与数据结构》实验二报告
20172329 2018-2019-2 <Java软件结构与数据结构>实验二报告 课程:<Java软件结构与数据结构> 班级: 1723 姓名: 王文彬 学号:2017232 ...
- 20172301 《Java软件结构与数据结构》实验一报告
20172301 <Java软件结构与数据结构>实验一报告 课程:<Java软件结构与数据结构> 班级: 1723 姓名: 郭恺 学号:20172301 实验教师:王志强老师 ...
随机推荐
- 洛谷P4602 [CTSC2018]混合果汁(主席树)
题目描述 小 R 热衷于做黑暗料理,尤其是混合果汁. 商店里有 nn 种果汁,编号为 0,1,\cdots,n-10,1,⋯,n−1 . ii 号果汁的美味度是 d_idi ,每升价格为 p_ipi ...
- float(浮动)的属性和使用方法
1float浮动的属性值 left:向左浮动 right:向右浮动 2.当父元素未浮动,子元素浮动时,就会造成浮动塌陷 实例: 父元素: #mainDiv{ border: 5px solid red ...
- error:0906D064:PEM routines:PEM_read_bio:bad base64 decode
今天在使用easywechat对接企业打款到银行卡时,遇到了两个错误 error:0906D064:PEM routines:PEM_read_bio:bad base64 decode 和 erro ...
- 触摸屏之linux3.4.2安装tslib
1. 写好触摸屏驱动后,安装tslib 1.1 tar xzf tslib-1.4.tar.gz 1.2 cd tslib 1.3 修改编译器版本号或者内核版本号,使它们一致.不然会出错,显示sele ...
- 截图:【炼数成金】深度学习框架Tensorflow学习与应用
创建图.启动图 Shift+Tab Tab 变量介绍: F etch Feed 简单的模型构造 :线性回归 MNIST数据集 Softmax函数 非线性回归神经网络 MINIST数据集分类器简单版 ...
- 局域网,Internet,广域网
局域网:覆盖范围小,自己花钱买设备,带宽固定,自己单位维护 网线100米以内 带宽10m 100m 1000m Internet:ISP,自己的机房,对网民提供访问Internet连接 广域网:距离远 ...
- Java NIO (1)
Java NIO (1) 看了下java核心技术这本书 关于nio的部分介绍比较少,而且如果自己写服务器的话nio用的还是比较多,整理一下nio的资料 java中nio主要是三个组件 Buffers ...
- Go学习笔记01
前言 Go(Golang)是Google开发的一种强静态类型.编译型.并发型,并具有垃圾回收功能的编程语言,所以使用Go编写的程序相比nodejs之类的弱类型语言,可以提前在编译阶段发现错误,而且由于 ...
- python 内置调试工具 pdb
除了 pycharm 可以调试python外,python自带的内置工具pdb 也可以调试 python.其命令方式类似于 gdb. pdb 常用的调试命令见下表. 命令 解释 break 或 b 设 ...
- 20155322 2016-2017-2《Java程序设计》课程总结
学号 2016-2017-2<Java程序设计>课程总结 (按顺序)每周作业链接汇总 预备作业一:浅谈对师生关系的看法以及对未来学习生活的展望 预备作业二:学习娄老师<做中学> ...