- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
算法导论第二章
《算法导论》第二章----插入排序(伪代码实现、课后习题(递归版本、二分查找策略版本))
插入排序是算导第一个分析的算法。
之前看了很多遍,一直没有把习题做了,现在好好把习题和思考题做做,锻炼自己能力,顺便用C语言实现经典算法和数据结构。
最基础的插入排序是对前n-1项数据进行反向扫描。实现很简单,运行时间也很容易的出,直接贴代码:
void insertion_sort(int A[], int length)
{
int i, j;
int key;
for(j = 1; j length; j++)
{
key = A[j];
i = j - 1;
while(i = 0 A[i] key)
{
A[i+1] = A[i];
i--;
}
A[i+1] = key;
}
}
练习题2.3-4要求将插入排序改写成递归过程。实现也是比较简单。
void insertion(int A[], int length){
if(length != 1){
int key = A[length-1];
int i = length-2;
while(i = 0 A[i] key){
A[i+1] = A[i];
i--;
}
A[i+1] = key;
}
}
void insertion_sort(int A[], int length){
if(length 1){
insertion_sort(A, length-1);
insertion(A, length);
}
}
练习2.3-6要求将最基础版本中的线性查找策略改成二分查找。
int binary_search(int A[], int key, int end){
int i = 0;
int j = end;
int m;
while(i j){
m = (i + j) / 2;
if(key A[m]){
i = m + 1;
}
else{
j = m;
}
}
if(A[i] = key)
return i;
else
return i + 1;
}
void insertion_sort(int A[], int length){
int i, j;
int key;
int pos;
for(j = 1; j length; j++)
{
key = A[j];
pos = binary_search(A, key, j-1);
for(i = j-1; i = pos; i--)
A[i+1] = A[i];
A[pos] = key;
}
}
算法导论第二章习题答案
摘自:/blog/1328678
2.1插入排序
2.1-1 以图2-2为模型,说明INSERTION-SORT在数组A=31,41,59,26,41,58上的执行过程。
31 41 59 26 41 58
31 41 59 26 41 58
31 41 59 26 41 58
26 31 41 59 41 58
26 31 41 41 59 58
26 31 41 41 58 59 注:红色表示要准备插入的数,蓝色表示与红色数字比较过的数。
2.1-2 重写过程INSERTION-SORT,使之按非升序(而不是按非降序)排序。
伪代码如下:
INSERTION-SORT(A) for j←to length[A] do key←A[J] i←j-1 while i0 and A[i]key do A[i+1]←A[i] i←i-1 A[i+1]←key
2.1-3 查找问题:
输入:一列数A={a1, a2, ...an}和值v。
输出:下标i,使
您可能关注的文档
最近下载
- 2023年外贸单证实务试卷题库和答案.doc VIP
- 消防安全重点单位消防档案.docx VIP
- 考前必备2025年四川省巴中市公务员省考公共基础知识测试卷(含答案.pdf VIP
- 教学课件:《思想政治学科教学新论》(第二版)刘强.ppt
- 2025云南怒江州福贡县义务教育教师专项招聘65人笔试备考试题及答案解析.docx VIP
- Unit 3 课时5 Word power(课件)-2025-2026学年八年级英语上册(译林版2024).pptx
- DB44/T 2457-2024地质灾害自动化监测规范.docx
- 流程制度文件评审制度及表单.docx VIP
- 2025年职业学院专任教师辅导员招聘考试笔试试题(含答案).docx VIP
- 基于BIM技术的铁路施工管理与协同方案研究.pptx VIP
文档评论(0)