20182319 2019-2020-1 《数据结构与面向对象程序设计》实验六报告
课程:《程序设计与数据结构》
班级: 1823
姓名: 彭淼迪
学号:20182319
实验教师:王志强
实验日期:2019年10月30日
必修/选修: 必修
1.实验内容
1.链表练习,要求实现下列功能:
- 通过键盘输入一些整数,建立一个链表;
这些数是你学号中依次取出的两位数。 再加上今天的时间。
例如你的学号是 20172301
今天时间是 2018/10/1, 16:23:49秒
数字就是
20, 17,23,1, 20, 18,10,1,16,23,49
打印所有链表元素, 并输出元素的总数。
在你的程序中,请用一个特殊变量名来纪录元素的总数,变量名就是你的名字。 例如你叫 张三, 那么这个变量名就是
int nZhangSan = 0; //初始化为 0.
做完这一步,把你的程序签入源代码控制(git push)。
2.链表练习,要求实现下列功能:
- 实现节点插入、删除、输出操作;
继续你上一个程序, 扩展它的功能,每做完一个新功能,或者写了超过10行新代码,就签入代码,提交到源代码服务器;
从磁盘读取一个文件, 这个文件有两个数字。
从文件中读入数字1, 插入到链表第 5 位,并打印所有数字,和元素的总数。 保留这个链表,继续下面的操作。
从文件中读入数字2, 插入到链表第 0 位,并打印所有数字,和元素的总数。 保留这个链表,并继续下面的操作。
从链表中删除刚才的数字1. 并打印所有数字和元素的总数。
3.链表练习,要求实现下列功能:
•使用冒泡排序法或者选择排序法根据数值大小对链表进行排序;
如果你学号是单数, 选择冒泡排序, 否则选择选择排序。
在排序的每一个轮次中, 打印元素的总数,和目前链表的所有元素。
在(2)得到的程序中继续扩展, 用同一个程序文件,写不同的函数来实现这个功能。 仍然用 nZhangSan (你的名字)来表示元素的总数。
4.在android上实现实验(1)和(2)
5.在android平台上实现实验(3)
2. 实验过程及结果
总体上来说,是一个为了让我们对于实现链表有一个更加深入的了解的实验,在这中间有从元素的插入到整个序列的排序甚至在安卓中使用它一整个过程。但其实上个星期我们已经做过了类似的实验。
实验一:
首先是对于链表的插入和输出,这个是对于一个链表比较基础的一部分,但我们可以想到上周我们已经实现了链表的基本功能,所以我们在进行编写的时候其实只是多加了一个npmd。
其实这里面我没有写太多什么东西,大多还是没用以前的那个linear。
实验二
这一次也是和上次一样,要求我们实现插入与删除,但在这一次,我碰到了一点小麻烦,那个npmd不是特别好计算,其实可以直接放在结构体中,但我出于习惯把它们新弄了一个方法。顺手把第一个的也给改了。
实验三
这个与前面两个差不多,但它有一个地方不同的就是,我们需要从文件中读取一些数据把它们加入到链表中,这当中有两个难点,首先是如何读取,这个前面的实验中其实也已经实现了,但它们读取是string,如何把它们变成数字呢,我用了一点替代。在问题中会有提到。
实验四、五:
把前面的代码放在andriod中再实现一遍,开始还是有点不顺手,但用着也还是可以了。
3. 实验过程中遇到的问题和解决过程
- 问题1:我们如何在给head赋值,开始的时候,我没有给它赋值,于是我就老是有地址越界的错误,怎么搞也搞不懂,后面才注意到。
- 问题1解决方案:对此,我想了两种方法,其一是我们直接在有了第一个数之后才开始定义这个head,这样的话它一出生就是有初值的。不会越界,也不会多0。其二是我们可以加一个判定条件,当head的什不是多少时证明它不是没有指向的,否则有指向,根据情况不同赋不同的值。
方法一
方法二
- 问题2:我们从文件中读取到的是一些字符我们明显是不能把它们加进数组的。
- 问题2解决方案:我认为可以充分得用ASCII的特点,我们把其中在0~9之间的字符拿出来,然后用一个数来接住它们,这个数从0开始,每次遇到数后就乘10加数,遇到其它字符就置0,这样的话就可以把它们都变成数字了。