第一范文网 - 专业文章范例文档资料分享平台

分治算法实验报告

来源:用户分享 时间:2025/8/24 23:01:44 本文由loading 分享 下载这篇文档手机版
说明:文章内容仅供预览,部分内容可能不全,需要完整文档或者需要复制内容,请下载word后使用。下载word有问题请添加微信号:xxxxxxx或QQ:xxxxxx 处理(尽可能给您提供完整文档),感谢您的支持与谅解。

算法分析与设计实验报告

第 1 次实验

姓名 时间 实验名称 10.17上午 学号 地点 四合院102 班级 分治算法实验(用分治法查找数组元素的最大值和最小值)。 实验目的 通过上机实验,要求掌握分治算法的问题描述、算法设计思想、程序设计。 在满足分治法的条件下,根据不同的输入用例,能准确的输出用例中的最大值与最小值。并计算出程序运行所需要的时间。 分治法的基本思想是将一个规模为n的问题分解为k个规模较小的子问题,这些子问题互相独立且与原问题相同。递归地解这些子问题,然后将各子问题的解合并得到原问题的解。 ① 先解决小规模的问题,如数组中只有1 个元素或者只有两个元素时候 的情况。 ② 将问题分解,如果数组的元素大于等于3 个,将数组分为两个小的数 组。 ③ 递归的解各子问题,将(中分解的两个小的数组再进行以上两个步骤 ((最后都化为小规模问题。 ④ 将各子问题的解进行比较最终得到原问题的解。 void SelectMaxMin(int *a,int i,int j,int &max,int &min) { if(i==j) { max= a[i]; min =a[i]; return; } else { int mid=(i+j)/2; int maxi,maxj,mini,minj; SelectMaxMin(a,i,(i+j)/2,maxi,mini); SelectMaxMin(a,((i+j)/2)+1,j,maxj,minj); 实验原理 实验步骤 关键代码 if(maxi>maxj) max=maxi; else max=maxj; if(mini

附录:完整代码

SelectMaxMin.cpp:

#include #include #include #include #include using namespace std;

void SelectMaxMin(int *a,int i,int j,int &max,int &min) {

if(i==j) {

max= a[i]; min =a[i]; return; } else {

int mid=(i+j)/2;

int maxi,maxj,mini,minj;

SelectMaxMin(a,i,(i+j)/2,maxi,mini); SelectMaxMin(a,((i+j)/2)+1,j,maxj,minj);

if(maxi>maxj) max=maxi; else

max=maxj;

if(mini

else

min=minj; return; } }

int main() {

clock_t start,end,over; start=clock(); end=clock(); over=end-start; start=clock();

//freopen(\ //freopen(\ int m;

cout <<\ cin>> m; int a[m];

srand((unsigned int)time(NULL)); cout << \随机产生的数据(0-100):\ for(int i=0; i

SelectMaxMin(a,0,m-1,max,min); cout << \ cout << \

end=clock();

printf(\ }

搜索更多关于: 分治算法实验报告 的文档
分治算法实验报告.doc 将本文的Word文档下载到电脑,方便复制、编辑、收藏和打印
本文链接:https://www.diyifanwen.net/c3taoh3g3y29s4tl8lgrm6o2vt5lzj600cqu_1.html(转载请注明文章来源)
热门推荐
Copyright © 2012-2023 第一范文网 版权所有 免责声明 | 联系我们
声明 :本网站尊重并保护知识产权,根据《信息网络传播权保护条例》,如果我们转载的作品侵犯了您的权利,请在一个月内通知我们,我们会及时删除。
客服QQ:xxxxxx 邮箱:xxxxxx@qq.com
渝ICP备2023013149号
Top