- 1、本文档共13页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
实验报告
实验一:
实验名称
二分搜索法
实验目的
编写程序实现用二分法在一有序序列中查找一个数
实验内容
程序源代码
#includestdio.h
int Research(int a[],int x,int n)
{
int left=0,right=n-1,mid;
if(n0x=a[0])
{
while(leftright)
{
mid=(left+right+1)/2;
if(xa[mid])
right=mid-1;
else
left=mid;
}
if(x==a[left])
return left;
}
return -1;
}
void Input()
{
int a[30],n,i,j,x;
printf(输入数组长度 n :);
scanf(%d,n);
printf(输入有序数组:\n\n);
for(i=0;in;i++)
{
printf(a[%d]:,i);
scanf(%d,a[i]);
}
printf(输入要查询的数字:);
scanf(%d,x);
j=Research(a,x,n);
if(j=0)
printf(%d 在数组中的下标为 %d!\n\n,x,j);
else
printf(没找到!\n\n);
}
main()
{
Input();
}
运行结果
图一
图二
实验心得:本次实验让我了解了二分搜索法的基本思想,同时我们应该注意二分搜索法必须是在有序的元素中进行,不能在无序的元素中使用。
快速排序:
#includeiostream
using namespace std;
#define MAXSIZE 100
int Partition(int q[MAXSIZE],int low,int hight);
void Qsort(int q[],int low,int hight);
int main()
{
int q[MAXSIZE]; //存储数列的数组
q[0]=0;
int n=0;
cout请输入需要排序的数的个数:;
cinn;
cout\n请输入需要排序的数:\n;
for(int i=1;i=n;i++) //用循环方式输入数列
{
cinq[i];
}
Qsort(q,1,n); //调用Partition()函数
cout\n排序后结果为:\n;
for(i=1;i=n;i++) //循环输出结果
{
coutq[i] ;
}
coutendl;
return 0;
}
int Partition(int q[MAXSIZE],int low,int high) //对数列及数列部分划分成高低两个部分
{
int pivotkey; //用于标记q[low]这个关键数
q[0]=q[low]; //q[0]用于存储q[low]这个数,q[low]空出
pivotkey=q[low];
while(lowhigh) //判断长度是否大于1
{
while(lowhigh q[high]=pivotkey)
high--;
q[low]=q[high]; //当pivotkey的值大于q[high],将q[high]放入q[low]中,q[high]空出
while(lowhigh q[low]=pivotkey)
low++;
q[high]=q[low]; //当pivotkey的值小于q[low],将q[low]放入q[high]中,q[low]空出
}
q[low]=q[0]; //将q[0]中存储的数放入它合适的位置
return low;
}
void Qsort(int q[MAXSIZE],int low,int high)
{
int pivotkey; //记录关键数上一次排序后的位子
if(lowhigh)
{
pivotkey=Partition(q,low,high);
Qsort(q,low,pivotkey-1); //对比关键数小的数(左侧)排序
Qsort(q,pivotkey+1,high); //对比关键数大的数(右侧)排序
}
}
运行结果:
实验总结: 在实验过程中,我只考虑了对数进行排序,没有其他的指针,所以就直接用了int型的数组。在将数组分块排序中,我用了递归的思想,提高了程序的可读性。
实验二:
实验名称
求最长公共子序列
实验目的
编写程序掌握动态规划法中关于最长公共子序列的实现实验内容
三、实验内容
实验源代码
#include stdio.h
#incl
您可能关注的文档
- 扔色字课程设计报告正文.doc
- 产品市场调查报告内容.doc
- 数据库课程设计报告_5.doc
- 六年级上册信息第三单元《第3课算法的描述》教案.doc
- 数字秒表课程设计报告_4.doc
- 天津市宝坻区第二中学2021-2021学年八年级第一学期第一次月考数学试卷(无答案).doc
- 示范幼儿园评估汇报材料.doc
- 湘少版四年级上册英语Unit 2.ppt
- 用FFT对信号作频谱分析_2.doc
- 北信科大DSP实验报告.doc
- 安全生产考核奖惩制度3篇.doc
- 颅脑损伤病人的护理查房【优质公开课】精品PPT课件模板.pptx
- 二零二二年度德州继续教育公需科目《公共事务管理与服务能力》试题及答案.pdf
- 二零二二年度党风廉政建设知识竞赛题库(含答案).pdf
- 二零二二年度度枣庄市专业技术人员继续教育公需科目培训班互动题.pdf
- 二零二二年度儿童保健学试题库(含答案).pdf
- 二零二二年度第十九届中国东南地区数学奥林匹克竞赛高一试题(含答案).pdf
- 二零二二年度动物卫生监督题库(含答案).pdf
- 黑龙江省大庆市重点中学2023-2025学年高一下学期2月开学考试英语试题(含解析).docx
- 二零二二年度法检书记员招考《公基》测试题库(含答案).pdf
文档评论(0)