- 1、本文档共50页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
?
第一章概论 练习答案
上一章 ??下一章
本章练习题
答案分页:??[1] [2]
1、解答:
【题意解析】
?????? ASCII字符顺序来排序。
【典型错误】
1.不按照题目给出的字符顺序进行排序,而按照ASCII字符顺序。
2.
3.认为顺序存储法比较节约空间,事实上由于字符空隙,顺序法并不节约空间;
4. 没有比较各种方法的优劣。
【数据结构】
??????
1. 用二维数组array[NUMOFSTRING][MAX_LENGTH],此题可定义const int NUMOFSTRING=8, MAX_LENGTH=5;
B
8
9
9
\0
B
9
\0
?
?
C
R
S
I
\0
C
X
Y
\0
?
P
A
B
\0
?
P
A
B
C
\0
5
C
\0
?
?
7
\0
?
?
?
优点:为紧凑存储结构,没有用于存储其他附加的信息,表示方法比较直观简单,代码实现十分容易。???? 缺点:为每个但此都开辟了同样长度的空间,造成空间的浪费。???? 2. 用链表的结构存储,结点为结构
????????????? struct strings{
????????????? ??? char string[MAX_LENGTH];
????????????? ??? strings *pNext;
????????????? }
?
优点:如果有后续工作如反复增删结点,效率很高.并且可以使用不连续的空间。???? 缺点:操作过程相对复杂,容易出错.而且排序过程需要从表头开始沿链索一个结点一个结点的比较搜索,相当费时。?
3. 索引存储??? 是顺序存储的一种推广.使用一个字符串char data[500],其中将大小长度不等的数据结点(单词)顺序存储其中.令使用一个字符指针数组 char* index[n],存储一系列指针,每个指针指向存储区域的一个数据结点.??? 排序时,直接对index中的地址值进行调换修改即可,而不用修改data中的任何内容。索引存储的优点是:由于单词长度不同,在存储时充分考虑了这个因素,可以节省空间,此外由于交换的不是单词本身而是单词的地址,可以节省时间,从时空两方面得到了优化。【排序结果】B899B9,CRSI,CXY,PAB,PABC,5C,7????????????
2、解答: 【题意解析】?????100个实数是否存在相等的情况,在这里,我们考虑存在多个最大值的情形(即100个实数可能有相等的),为了保存其位置,利用int pos[100](因为有可能这100个实数都是相同的)来保存最大值的所有位置。【典型错误】?????1. int类型的数组来保存这100个元素,没有注意题目中说的是“每个元素的值都是实数”。???? 2. 求最大值的时候代码如下:??? ???? ???????? temp=0;??? ????????????? for(int i=0;i100;i++)?????? ??????????????? if(Num[i]temp)???? ?????????? ? temp=Num[i];评注:这样是错误的,例如:当Num[i]都是负数的时候。???? 3. 未考虑可能存在多个最大值的情况,只保存了一个最大值的位置。【数据结构】?????【算法描述】???? 1. 100的整型数组pos[100],用来记录最大值的位置。? ?? 2. 初始情况,取这个数组的第一个位置为最大值所在的位置,存入变量position中。???? 3. 假设有n(1≤n≤99)个最大值,那么pos[0, 1, 2, …, n-1]记录这些最大值的位置,且pos[n]=-1(-1是标记值,表明pos数组下标为n-1及以前的元素记录了最大值的位置);假设有n(n=100)个最大值,那么pos[0, 1, 2, …, n-1]记录这些最大值的位置,pos数组不再设-1的标记值。具体源码如下:??? # include iostream.h??? void main(){?????? //存放100个实数的数组?????? double Num[100]={4543.9,4543.9,3,45,654.7,7,66,35,45,4,6,4543.9,5,46,54,6,43,5.980,34};?? ?????? //记录最大值所在位置的数组?????? int pos[100]; ?????? //初始设定数组的第1个元素为最大值?????? int position=0; ?????? //j指示位置数组pos的下标?????? i
您可能关注的文档
最近下载
- 基于大模型的生成式检索.pdf VIP
- 西门子伺服操作说明书-SINAMICS_V90_OPI.pdf VIP
- 电力工程施工安全与质量控制管理.docx VIP
- Packing List-装箱单表格模板.xls VIP
- 电力工程施工安全及质量控制管理.doc VIP
- 2025年最新版硫化氢考试题库大全集.doc VIP
- [江西]发电厂2×600mw级机组“上大压小”土建工程施工组织设计.doc VIP
- 《护患沟通技巧》ppt课件.pptx VIP
- 县乡教师选调进城考试《教育心理学》题库及答案(各地真题).docx VIP
- 发电厂“上大压小”2×600MW超临界空冷机组工程土建专业主要施工方案.docx VIP
文档评论(0)