- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
线性时间选择算法
福州大学数学与计算机科学学院
《计算机算法设计与分析》上机实验报告(1)
专业和班级 数学02班 姓名 詹小青 成绩 学号 031201206 实验名称 线性时间选择算法 实验目的 通过实验,至少掌握一种线性时间选择算法 实验任务
设计一种线性时间选择算法,证明算法的正确性并且分析它的时间复杂度。
实验步骤 1、算法设计思想(最坏情况线性时间做选择):
这种算法基本思想是保证每个数组的划分都是一个好的划分,以5为基,五数取分。利用它的思想,可以快速返回和最终中位数相差不超过2的数,这样的划分接近最优,基本每次都二分了。
2、算法基本步骤:
算法SELECT通过执行下列步骤来确定一个有n个元素的输入数组中的第i个小的元素。
1)将输入数组的n个元素划分为n/5组,每组5个元素,且至多有一个组由剩下的n mod 5个元素组成;
2)寻找n/5个组中每一组的中位数。(方法首先对每组中的元素进行插入排序,然后从排序过的序列中选出中位数);
3)对第2步中找出的n/5个中位数,递归调用SELECT找出其中位数x。(如果有偶数个中位数,根据约定,x是下中位数。)
4)利用修改过的PARTITION过程,按中位数的中位数x对输入数组进行划分。让k比划分低区的元素多1,所以x是第k小的元素,并且有n-k个元素在划分的高区;
5)如果i=k,则返回x,否则,如果ik,则在低区递归调用SELECT以找出第i小的元素,如果ik,则在高区找第(i-k)个最小元素。
3、时间复杂度分析:
图中箭头指向表示大的数值指向小的数值,所以根据图可以看出,在x的右边,每一个包含5个元素的组中至少有3个元素大于x,在x的左边,每一组中至少有3个元素小于x(保证x分割一边必定有元素存在)。
图中显示的中位数的中位数x的位置,每次选取x作为划分的好处是能够保证必定有一部分在x的一边。所以算法最坏情况的递归公式可以写成:
,使用替换法可以得出。
4、算法代码:
#include iostream
#include ctime
using namespace std;
template class Type
void Swap(Type x,Type y);
inline int Random(int x, int y);
template class Type
int Partition(Type a[],int p,int r);
templateclass Type
int RandomizedPartition(Type a[],int p,int r);
template class Type
Type RandomizedSelect(Type a[],int p,int r,int k);
int main()
{
void SelectionSort(int a[]);
int s;
int a[2000];
int b[2000];
for(int i=0; i2000; i++)
{
a[i]=b[i]=rand()%10000;
couta[i] ;
}
coutendl;
SelectionSort(b);
for(int j=0;j2000;j++)
{
printf(a[%d]:%d ,j+1,b[j]);
}
coutendl;
printf(请输入要求的第几最小数:);
scanf(%d,s);
coutRandomizedSelect(a,0,1999,s)endl;
}
template class Type
void Swap(Type x,Type y)
{
Type temp = x;
x = y;
y = temp;
}
inline int Random(int x, int y)
{
srand((unsigned)time(0));
int ran_num = rand() % (y - x) + x;
return ran_num;
}
template class Type
int Partition(Type a[],int p,int r)
{
int i = p,j = r + 1;
Type x = a[p];
while(true)
{
while(a
您可能关注的文档
最近下载
- (高清版)B-T 2099.1-2021 家用和类似用途插头插座 第1部分:通用要求.pdf VIP
- 劳动创造美好生活中职生劳动教育全套教学课件.pptx
- 人工智能在高中美术课堂中的应用.pdf
- 西藏自治区日喀则市高一入学数学分班考试真题含答案.docx VIP
- 2025黑龙江省建设投资集团有限公司面向系统内部及社会招聘12人笔试备考试题及答案解析.docx VIP
- 医院医德医风考评公示制度医德医风考评制度及考评实施细则.docx
- 晶体工程资料.pdf VIP
- 成都川师锦华小升初入学分班考试英语考试试题及答案.docx VIP
- 第六章晶体工程.ppt VIP
- ASUS华硕ROG SWIFT PG65UQ中文说明书.pdf VIP
文档评论(0)