- 1、本文档共20页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
PAGE
PAGE # / 19
《算法设计与分析》
、 排序和查找是经常遇到的问题。按照要求完成以下各题:
对数组A={15,29, 135,18, 32, 1, 27, 25, 5},用快速排序方法将其排成递减序。
解:(1)第一
步:15 29 135 18 32 1 27 25 5
第二步:
29 135 18 32 27 25 15 1 5
第三步:
135 32 29 18 27 25 15 5 1
第四步:
135 32 29 27 25 18 15 5 1
请描述递减数组进行二分搜索的基本思想,并给出非递归算法。
解:基本思想:首先将待搜索元素 v与数组的中间元素 A n进行比较,如果v A -,
〔2 」 12 J
则在前半部分元素中搜索 v ;若v=A n,则搜索成功;否则在后半部分数组中搜索 v。
IL2
非递归算法:
输入:递减数组 A[left:right] ,待搜索元素v。
输出:v在A中的位置pos,或者不在A中的消息(-1 )。
步骤:
int Bin arySearch(i nt A[],i nt left,i nt right, int v)
{
int mid;
while (left=right)
{
mid=i nt((left+right)/2);
if (v==A[mid]) return mid;
else if (vA[mid]) right=mid-1;
else left=mid+1;
}
return -1;
}
给出上述算法的递归算法。
解:输入:递减数组 A[left:right] ,待搜索元素 V。
输出:v在A中的位置pos,或者不在A中的消息(-1 )。
步骤:【3分】
int Bin arySearch(i nt A[],i nt left,i nt right, int v)
{
int mid;
if (left=right)
{
mid=i nt((left+right)/2);
if (v==A[mid]) return mid;
else if (vA[mid]) retur n Bin arySearch(A,left,mid-1,v);
else return Bi narySearch(A,mid+1,right,v);
}
else
return -1;
}
(4)使用上述算法对(1)所得到的结果搜索如下元素,并给出搜索过程: 18, 31 ,135。
解:搜索18:首先与27比较,1827,在后半部分搜索;再次与 18比较,搜索到,返回 5。 搜索31:首先与27比较,3127,在前半部分搜索;再次 32比较,3132,在后半部 分搜索,与29比较,3129,此时只有一个元素,未找到,返回 -1。
搜索135:首先与27比较,13527,在前半部分搜索;再次 32比较,13532,在前半 部分搜索;与135比较,相同,返回 0。
二、排序和查找是常用的计算机算法。按照要求完成以下各题:
对数组A={15 , 9, 115, 118, 3, 90, 27, 25, 5},使用合并排序方法将其排成递减序。
若改变二分搜索法为三分搜索法, 即从一个递减序列 A中寻找元素乙先与元素A{卫]比
3
较,若Z A[-],则在前面呼]个元素中寻找Z;否则与艸却]比较,总之使余下的序列为[卫]
3 3 3 3
个元素。给出该方法的伪代码描述。
使用上述算法对(1)所得到的结果搜索如下元素,并给出搜索过程: 118, 31, 25。
解:(1 )第一步:15 9 115 118 3 90 27 25 5
第二步:15 9 118 115 90 3 27 25 5
第三步:118 115 15 9 90 27 25 3 5
第四步:118 115 90 27 25 15 9 3 5
第五步:118 115 90 27 25 15 9 5 3
输入:递减数组 A[left:right] ,待搜索元素v。
输出:v在A中的位置pos,或者不在A中的消息(-1 )。
步骤:
int Bin arySearch(i nt A[],i nt left,i nt right, int v)
{
int mid;
while (left=right)
{
first=left+(right-left+1)/3;
seco nd=left+(right-left+1)/3*2;
if (v==A[first]) return first;
else if (vA[first]) right=first-1;
else if (v==A[sec on d]) retur n sec ond;
else if (vA[sec on d]) {left=first+1;
您可能关注的文档
- 最新足浴点钟宝管理系统方案及预算.docx
- 最新足底筋膜炎解析.docx
- 最新走进化学实验室综合练习.docx
- 最新自费图书出版合同.docx
- 最新自费出版协议.docx
- 最新装载机司机雇佣合同.docx
- 最新专题:二项分布与超几何分布.docx
- 最新轴温检测系统.docx
- 最新注册电气工程师基础考试高等数学试题.docx
- 最新智慧校园网络解决方案.docx
- 2024年05月山东交通职业学院招考聘用博士研究生50人笔试历年典型题及考点剖析附带答案含详解.docx
- 2024年05月安徽芜湖市弋江区老年学校(大学)工作人员特设岗位公开招聘2人笔试历年典型题及考点剖析附带答案含详解.docx
- 2024年05月山东东营河口区教育类事业单位招考聘用22人笔试历年典型题及考点剖析附带答案含详解.docx
- 2024年05月山东交通职业学院招考聘用100人笔试历年典型题及考点剖析附带答案含详解.docx
- 2024年05月山东威海职业学院招考聘用高层次人才2人笔试历年典型题及考点剖析附带答案含详解.docx
- 2024年05月安徽石台县事业单位工作人员33人笔试历年典型题及考点剖析附带答案含详解.docx
- 2024年05月山东滨州市博兴县事业单位公开招聘考察笔试历年典型题及考点剖析附带答案含详解.docx
- 2024年05月安徽蚌埠固镇县湖沟镇选聘村级后备干部7人笔试历年典型题及考点剖析附带答案含详解.docx
- 2024年05月山东省安丘市教育和体育局所属事业单位学校公开2024年招考232名工作人员笔试历年典型题及考点剖析附带答案含详解.docx
- 2024年05月山东临沂临港经济开发区工作人员(5人)笔试历年典型题及考点剖析附带答案含详解.docx
文档评论(0)