1300062702曾繁辉第一次上机报告.pdfVIP

  1. 1、本文档共7页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
数算第一次上机报告 1300062702 曾繁辉 1. 【题目阐释】已知线性表A,其长度为n, 采用顺序存储结构。写出顺序表置 逆后第一个值不大于 x,不小于y 的元素的前驱和后继的函数。 【题目分析】此题主要分为四个步骤:其一,用顺序表存储数据;其二,将顺序表置逆;其三, 寻找符合题目要求的点;其四,输出前驱和后继。初步分析,需要用结构体进行数据的存储,用指针 对表中数据进行查找操作。由于涉及到传参数的问题,所以必须定义指针,以便将找到的数值返回。 【代码实现】 这部分主要在进行头文件的声明、数据类型的定义、结构体的定义。考虑到结构体中主要含有2个类 型的变量——实际长度n, 以及数组element用于存放数据。另外,定义PSeqList作为结构体指针变量, 用于之后函数对结构体进行操作。 这部分代码包含程序的两个主要函数——定位函数与倒置函数。 定位函数,将传过来的线性表进行操作。其中,palist-n 用于确定需要查找的步骤数目; palist-element 用于对具体的数组元素进行调用与操作。定位函数的精髓,在于对符合条件的第一 个元素的位置进行了判断。如果第一个符合最大最小值条件的数位于首位或者末位,函数将返回一个 负值,以便进行合理的输出(不存在前驱或者不存在后继)。而如果符合条件的第一个数不位于首尾, 则返回0,并使用*pprev 与*pnext 进行正常赋值。 倒置函数比较简单,根据需要倒置的线性表中元素下标之和为n-1,将对应下标的数组元素进行互换 即可。 主函数部分。 首先进行相关元素的录入操作。之后声明并定义结构体与结构体指针。 尔后,先调用倒置函数对结构体中的数据进行倒置,再定义两个int 类型的指针变量*pprev、*pnext 用于表示所需要的前驱和后继。在每次定义指针之后,进行内存分配操作,再用指针指向对应的结构 体或者整形变量,用result表示查找函数locate_seq 的返回值,并根据其数值进行不同类型的输出。 最后,调用free 函数释放各个指针指向的内存。 【运行范例】 以上几组数据代表了各种输出的情况。需要注意的是,如果输入的最大值小于最小值,也会出现最后 一种结果,即“没找到,数据超出范围”。 【算法分析】 本程序的倒置操作对每个元素都进行了一次,复杂度为O(n)。查找操作的复杂度也为O(n),故综合 的时间复杂度为O(n)。内存的占用主要是结构体动态占用的内存,并不大。如果不强制使用倒置函 数,而是在存入数组的时候就按照下标逆序进行存储,则可以省略倒置函数和第二个结构体blist, 从而减少复杂度,节省时间和内存。 2. 【题目阐释】已知线性表A,其长度为n, 采用顺序存储结构。写出删除线性 表中所有值不小于x 的元素的函数。 【题目分析】本题比较简单,只需遍历数组中的每个元素,并对其中小于所给的x值的数进行输出 即可。如果没有符合条件的数,则输出错误信息。 【代码实现】 上图左边是头文件、构造结构体、结构体指针、定位函数的部分。与上一道题不同的地方也就在于函 数不同。在函数的执行期间,一旦数组中的某个元素复合小于阈值的条件,就执行以下步骤:数组长 度减一,该元素之后的元素向前进位1位,指针向前退一位。之所以指针向前退一位,就是因为下一 次循环的执行中指针还需要向后进一位,这样就保证了删除元素后,下一次判断时指针位置没有变。 上图右边是主函数部分。依次进行输入序列长度、构建数组,输入序列,输入阈值x,生成线性表等 操作。尔后,用指针指向结构体并分配内存,再让指针指向结构体,就可以调用函数locate_seq了。 最后,判断调用函数之后的palist-n是否为零,若是则输出提示信息——无可用输出。 【运行范例】 【算法分析】 本题目的算法比较简单。遍历数组长度时,如果在第n位发现需要删除的元素,则需要挪动的元素树 木为N-n。最大的可能性是从第一个元素开始,每个元素都符合删除条件,这样总操作次数大概是N^2 量级。所以时间复杂度是O(N^2)。占用的内存主要为线性表占用。 【收获体会】(前两题) (1)对结构体的使用更加熟悉,相应的赋值、指针、内存分配等语句可以顺利写出。 (2)对于顺序表基本函数操作能熟练运用了,比如插入、查找、易位等操作。 (3) 对于函数参数和指针变量的设计有了自己的体会。 (4)对于 debug 调试功能熟悉和了解了,这个功能非常实用,能跟踪变量的数值以及程序的执

文档评论(0)

ayangjiayu1 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档