- 1、本文档共7页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 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 调试功能熟悉和了解了,这个功能非常实用,能跟踪变量的数值以及程序的执
您可能关注的文档
- (修改)1.1DNA重组技术的基本工具.ppt
- (目录)中国B2C电子商务市场发展预测及投资咨询报告(目录).pdf
- (目录)中国化学药行业发展预测及投资咨询报告(目录).pdf
- (目录)中国植入式广告市场发展预测及投资咨询报告(目录).pdf
- (目录)中国餐饮连锁业发展预测及投资咨询报告(目录).pdf
- (高一生物试题)2014-2015学年第二学期期末教学质量监测高一生物试题.doc
- 07-时序图.ppt
- 09.09.27高一生物《必修1第2章第2节 遗传物质的携带者——核酸》.ppt
- 13帕金森病.ppt
- 2.4遗传图谱.ppt
- 半导体材料性能提升技术突破与应用案例分析报告.docx
- 半导体设备国产化政策支持下的关键技术突破与应用前景报告.docx
- 剧本杀市场2025年区域扩张策略研究报告.docx
- 剧本杀行业2025人才培训体系构建中的市场需求与供给分析.docx
- 剧本杀行业2025年人才培训行业人才培养模式创新与探索.docx
- 剧本杀行业2025年内容创作人才需求报告.docx
- 剧本杀行业2025年区域市场区域剧本市场消费者满意度与市场竞争力研究报告.docx
- 剧本杀市场2025年区域竞争态势下的区域合作策略分析报告.docx
- 剧本杀行业2025人才培训与行业人才培养模式创新.docx
- 剧本杀行业剧本创作人才心理素质培养报告.docx
文档评论(0)