课程:《程序设计与数据结构》
班级: 1823
姓名: 李金泉
学号:20182335
实验教师:王志强
实验日期:2019年10月日
必修/选修: 必修
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. 实验过程及结果
实验6(1)
实验6(2)
实验6(3)
实验6(4)
实验6(5)
3. 实验过程中遇到的问题和解决过程
- 问题1:执行排序算法过程中要求打印元素,使用array.toString方法会出现异常,具体是会出现乱码,或者部分toString方法不显示任何东西
问题1解决方案:选择其他的输出方式,如
for(int num:arr){
System.out.print(num+" ");
}
String str = "";
for (int x = 0; x < size(); x++){
str += array[x]+ " ";
}
这样的输出就没有问题。
问题2:冒泡排序的最后1,顺序已经从小到大排好,但依然在进行排序操作
问题2解决方案:表面上看顺序已经排好,但是双重循环操作还需要继续进行下去,计算机不可能直接识别这一串数字,只能按既定的操作走完,只要是排序次数小于最大值(数字从大到小排列通过冒泡排序变为从小到大排列的次数)就是正确的。
其他(感悟、思考等)
我对实验的过程还是不够了解和掌握,尤其是调试的过程中有很多步骤不知道它的具体意思,需要向同学请教和学习。以后会继续努力弄懂每个步骤。
参考资料
《Java程序设计与数据结构教程(第二版)》
《Java程序设计与数据结构教程(第二版)》学习指导
android中菜单的字体太小
Unable to resolve dependency for ':app@debug/compileClasspath': Could not resolv...【终极解决方案】
关于Android Studio在Design界面里手动调好了Layout布局之后,在模拟器运行却不一样的解决方案