数据结构实验要求

综合类实验设计3

已知有一组数据a1a2a3a4……anb1b2b3b4……bm,其中ai均大于bj,但是a1到an和b1到bm不是有序的,试设计两到三个算法完成数据排序,且把bj数据全倒置到ai之前,并比较几个算法之间的时空复杂度。

编写实验代码过程中的问题和解决过程

因为之前提到使用java语言实现数据结构和密码学的实验可以加分,并且自己的C语言确实也是随着自己没有巩固练习而淡忘的差不多了,而且张岩老师也允许使用java语言进行实验实现,所以第一次的数据结构实验我选择了java语言实现。之前我所编写的代码中,错误的把题目看成了一个数组,所以在我自信满满的给老师验收代码的时候一下子就被指出理解题目有误,之后我在课上修改了代码,但是这次又将全导致这一概念理解错误了。

我理解的是,将整个数组排序后,将每个bj提到对应的ai前,但是啊,真确的全导致是全部的bj提到全部的ai前面,所以我又发了第二次理解错误。

package cc.openhome;

public class shiyan1
{ public static void main(String[] args)
{
int[] scores1 = {88,81,74,68,78,76,77,85,95,93,87,80,73,67,77,75,76,84,94,92};
int temp;
int size = scores1.length;
for (int i = 0; i < size - 1; i++)
{
for (int j = i + 1; j < size; j++)
{
if (scores1[i] < scores1[j])
{
temp = scores1[i];
scores1[i] = scores1[j];
scores1[j] = temp;
}
}
}
int temp1;
int size1 = scores1.length;
for (int a = 0 , b = 1; a <=size - 1 && b <= size; a=a+2,b=b+2)
{
if (scores1[a] > scores1[b])
{
temp1 = scores1[a];
scores1[a] = scores1[b];
scores1[b] = temp1;
}
} for(int score : scores1)
{
System.out.printf("%3d",score);
}
System.out.println();
}
}

所以我不得不开始了第三次代码修改,这次我的思路是,先定义一个要求的数组,然后用两个数组分别copy原数组的ai部分和bj部分,之后进行排序,然后再将排序后数组合并打印出来。

为了实现这个思路我需要调用System.arraycopy函数进行数组的copy,但是我自己的只会copy前半个数组int[] scores1 = Arrays.copyOf(shuju,shuju.length/2);这个样子,后半个数组就不可以这个样子int[] scores2 = Arrays.copyOf(shuju.length/2,shuju.length);所以我在博客园中找到了调用API的方法如下

这里再介绍一下System.arraycopy这个函数,从JAVA API中找了一段。大家看一下。连接在文末。

public static voidarraycopy(Object src, int srcPos, Object dest, int destPos, int length)从指定源数组中复制一个数组,复制从指定的位置开始,到目标数组的指定位置结束。从src引用的源数组到dest引用的目标数组,数组组件的一个子序列被复制下来。被复制的组件的编号等于length参数。源数组中位置在srcPos到srcPos+length-1之间的组件被分别复制到目标数组中的destPos到destPos+length-1位置。
如果参数src和dest引用相同的数组对象,则复制的执行过程就好像首先将srcPos到srcPos+length-1位置 的组件复制到一个带有length组件的临时数组,然后再将此临时数组的内容复制到目标数组的destPos到 destPos+length-1位置一样。 If 如果dest为null,则抛出NullPointerException异常。 如果src为null, 则抛出NullPointerException异常,并且不会修改目标数组。 否则,只要下列任何情况为真,则抛出ArrayStoreException异常并且不会修改目标数组: src参数指的是非数组对象。
dest参数指的是非数组对象。
src参数和dest参数指的是那些其组件类型为不同基本类型的数组。
src参数指的是具有基本组件类型的数组且dest参数指的是具有引用组件类型的数组。
src参数指的是具有引用组件类型的数组且dest参数指的是具有基本组件类型的数组。 否则,只要下列任何情况为真,则抛出IndexOutOfBoundsException异常,并且不会修改目标数组: srcPos参数为负。
destPos参数为负。
length参数为负。
srcPos+length大于src.length,即源数组的长度。
destPos+length大于dest.length,即目标数组的长度。 否则,如果源数组中srcPos到srcPos+length-1位置上的实际组件通过分配转换并不能转换成目标数组的组 件类型,则抛出ArrayStoreException异常。在这种情况下,将k设置为比长度小的最小非负整数,这样就 无法将src[srcPos+k]转换为目标数组的组件类型;当抛出异常时,从srcPos到srcPos+k-1位置上的源数组 组件已经被复制到目标数组中的destPos到destPos+k-1位置,而目标数组中的其他位置不会被修改。(因 为已经详细说明过的那些限制,只能将此段落有效地应用于两个数组都有引用类型的组件类型的情况。) 参数:src- 源数组。
srcPos- 源数组中的起始位置。
dest- 目标数组。
destPos-
目标数据中的起始位置。
length-
要复制的数组元素的数量。
抛出:IndexOutOfBoundsException-
如果复制会导致对数组范围以外的数据的访问。
ArrayStoreException- 如果因为类型不匹配而使得无法将src数组中的元素存储到dest数组中。
NullPointerException- 如果src或dest为null。

之后修改后得得到了可以运行的代码,但是因为我的eclipse版本过低所以无法运行在JDK1.6之后的函数,大家有兴趣可以copy下来代码去运行一下。

package cc.openhome;
import java.util.Arrays;//调用这个Arrays类进行数组的复制
import java.lang.System;//调用这个类进行输出
public class shiyan2
{
public static int[] contact(int scores1[], int scores2[]){
int[] f = new int[scores1.length+scores2.length];
for(int i = 0 ; i < f.length; i++)
if(i < scores1.length)
f[i] = scores1[i];
else
f[i]= scores2[i-scores1.length];
return f;//以上是对于排序好的两个数组合并成一个新的数组时的函数的建立,复制时只按照两个数组的元素先后顺序,所以需要排序好后再进行复制。
} public static void main(String[] args)
{
int[] shuju ={88,81,74,68,78,76,77,85,95,93,87,80,73,67,77,75,76,84,94,92};//原数组的赋值 int[] scores1 = Arrays.copyOf(shuju,shuju.length/2);//将ai从原数组拆分出来
int scores2[] = new int[10];//定义新数组用来复制bj
System.arraycopy(shuju[10],scores2[0],shuju.length);//从原数组的第十位开始复制,复制到新数组的开始,之后依次复制。 int temp; //定义中间变量
int size = scores1.length; //定义ai数组的长度变量
for (int i = 0; i < size - 1; i++) //冒泡排序,开始遍历ai数组
{
for (int j = i + 1; j < size; j++)
{
if (scores1[i] < scores1[j])
{ // 交换两数的位置
temp = scores1[i]; //不断两两交换,将小数不断交换到数组前
scores1[i] = scores1[j];
scores1[j] = temp;
}
}
}
int size2 = scores2.length; //同对于ai数组的进行的冒泡排序进行对bj数组进行排序
for (int i = 0; i < size2 - 1; i++) {
for (int j = i + 1; j < size2; j++) {
if (scores2[i] < scores2[j]) {
temp = scores2[i];
scores2[i] = scores2[j];
scores2[j] = temp;
}
}
}
int scores3[] =ContactIntegerArray.contact(scores2, scores1);//合并数组时将bj数组放到ai数组前
for(int score : scores3)
{
System.out.printf("%3d",score);//打印合并数组
}
System.out.println();//输出换行 } }

其他(感悟、思考等,可选)

在本周的学习中书上代码比较多,由其是第一次见识到了五十行以上的长代码,在敲的时候因为开始的不是很理解,导致自己有次看串了行,编译的时候总是有错误,后来发现了这点,我删除了之前的建的class,然后先去看书,在基本理解代码之后重新敲代码,这次因为有着之前的经验和自己的对于代码的理解,中间也丢了几行代码但是自己在敲的时候,发现了程序缺了东西,立马就补了回来。

而且现在我们最近在做数据结构的实验,在之前写大致的实验预习代码的时候,我就是使用的JAVA语言,实验要求是几个排序算法解决问题,之前我用的思想其实基本上和C语言中的思想差不多,就是用java语言表达了出来,像是冒泡排序,但是第九章Sort系列给了我新的思路,打算之后改进代码的时候,结合书上的内容,进行一定改进,希望在之后的学习中,可以将JAVA语言和其他科目的编程实验进行融会贯通,不要只是学过了就是学过了。

参考资料

20145205 java语言实现数据结构实验一的更多相关文章

  1. 数据结构(java语言描述)

    概念性描述与<数据结构实例教程>大同小异,具体参考:http://www.cnblogs.com/bookwed/p/6763300.html. 概述 基本概念及术语 数据 信息的载体,是 ...

  2. 数据结构(Java语言描述)-第一章:概述

    第一章 概述 1.0 序言 自己为啥要学数据结构嘞,我觉得主要有以下三个原因: 前段时间在看并发编程时,发现aqs,corrunthashmap等底层都用到了数据结构,主要的有队列,还有链表,学习数据 ...

  3. Java程序设计与数据结构导论--读后感

    与我前面所读的<Java7基础教程>相比,此书不适合自学,更适合作为教材使用. 虽然此书完整覆盖了Java的知识点和数据结构的基础问题,并且对每个部分都做了基本说明.但是因为没有深入展开, ...

  4. java项目——数据结构实验报告

    java项目——数据结构总结报告 20135315  宋宸宁 实验要求 1.用java语言实现数据结构中的线性表.哈希表.树.图.队列.堆栈.排序查找算法的类. 2.设计集合框架,使用泛型实现各类. ...

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

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

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

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

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

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

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

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

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

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

随机推荐

  1. Python cumsums和cumprod函数

    >>>a = np.array([1,2,3],[4,5,6]]) >>>a array([[1,2,3], [4,5,6]]) >>>a.cum ...

  2. Fedora中允许mysql远程访问的几种方式

    Fedora中允许mysql远程访问,可以使用以下两种方式:a.改表. mysql>use mysql; mysql>update user set host = '%' where us ...

  3. ftp服务配置文件记录

    因为南京的客户死活要ftp服务而不是sftp,所以我作手用vsftp作为服务器,尝试在windows ftp软件登录进去,特记录vsftp的用法. 配置文件在/etc/vsftpd.conf 有如下代 ...

  4. python function parameter

    Python 2.7.10 (default, Oct 14 2015, 16:09:02) [GCC 5.2.1 20151010] on linux2 Type "copyright&q ...

  5. Markdown入门

    http://www.jianshu.com/p/1e402922ee32/ 有道云笔记支持Markdown

  6. RobotFrameWork(三)数据类型

    1.1 数字变量 执行结果: 1.2 布尔变量和None/null 执行结果: 1.3 字符串.元组.list和字典 执行结果: 1.4 space和empty 执行结果:

  7. 2014 39th ACM-ICPC 西安赛区 总结

    西安,打铁. 出发前听说是大赛区,签到的时候看了秩序册的队伍情况,264支队伍. 在听说是大赛区之前,我觉得我们队应该是银首,运气好+发挥超常的话或许有金,即保银冲金. 听到大赛区之后,觉得可能金区有 ...

  8. HTML是什么?如何使用?

    ①我们首先打开桌面DW网页开发器. 也可以是其他的开发器. ②打开之后那么我们创建一个新的文档: 点击创建之后出现下图: 一般我们不管用哪种网页开发器,都会最先呈现上图的状态,那么下面来解读一下这些文 ...

  9. Linux C编程学习之C语言简介---预处理、宏、文件包含……

    C的简介 C语言的结构极其紧凑,C语言是一种模块化的编程语言,整个程序可以分割为几个相对独立的功能模块,模块之间的相互调用和数据传递是非常方便的 C语言的表达能力十分强大.C语言兼顾了高级语言和汇编语 ...

  10. MyBatis学习(四)MyBatis和Spring整合

    MyBatis和Spring整合 思路 1.让spring管理SqlSessionFactory 2.让spring管理mapper对象和dao. 使用spring和mybatis整合开发mapper ...