- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
算法的描述方式可以有多种多样,比如可以用自然语言,如英语,但这是必须保证每条指令都是确定的。借助图形也可以表示算法,称为流程图,但只适用于小而简单的算法。
下面首先用自然语言描述排序的算法:
From those integers that are currently unsorted,find the smallest and place it next in the sorted list.
(在当前所有未排序的整数中,找出最小的一个,把它放在当前有序表的最后一个位置。)
这句话充分描述了排序问题,但他并不是算法。因为其中有几处疑问。例如,没有告诉我们数据与结果的存储方式。
下面我们用混合的方式尝试构建算法,它部分是c语言,部分是英语:
for (i=0;in;i++){
Examine list[i] to list[n-1] and suppose that the smallest integer is at list[min];
Interchange list[i] and list[min];
}
要把上述混合程序转换成真正的c语言,还必须实现两个已明确定义的子任务:找出最小值并与list[i]交换。其中交换可以用下面代码实现:
代码1:
void swap(int *x, int *y){
int temp=*x;
/*declares temp as an int and assignes to it the contents of what x points to*/
*x=*y;
/*stores what y points to into the location where x points*/
*y=temp;
/*places the contents of temp in location pointed by y*/
}
上面这段小程序也可以用宏来实现:
#define SWAP(x,y,t) ((t)=(x),(x)=(y),(y)=t)
两种实现各有优点,函数实现更易读,宏实现适用于所有变量类型。
现在,我们转向第一个子任务。这时的比较方法与我前面说过的冒泡排序法基本思想非常类似。只是现在相互交换的不是数据,而是指针。在每进行完一轮扫描之后只进行一次实质性的数据交换,这对于系统来说节省了不少执行成本。这个子任务的实现我们称它为函数sort。程序中用到定义在stlib.h中的函数rand,它产生一系列随机数传给sort。
下面是这段代码的整体表述:
代码2:
#include stdio.h
#include stdlib.h
#define MAX_SIZE 101
#define SWAP(x,y,t) ((t)=(x),(x)=(y),(y)=t)
void sort(int[],int);/*selection sort*/
void main(void)
{
int i,n;
int list[MAX_SIZE];
printf(Enter the number of numbers to generate: );
scanf(%d,n);
if(n1||nMAX_SIZE){
fprintf(stderr,Improper value of n\n);
exit(EXIT_FAILURE);
}
for (i=0;in;i++){ /* randomly generate numbers */
list[i]=rand()%100;
printf(%d ,list[i]);
}
sort(list,n);
printf(\nSorted array:\n);
for(i=0;in;i++)/* print out sorted numbers */
printf(%d ,list[i]);
printf(\n);
getch();
}
void sort(int list[],int n)
{
int i,j,min,temp;
for(i=0;in-1;i++){
min=i;
for(j=i+1;jn;j++){
if(list[j]list[min])
min=j;
}
SWAP(list[i],list[min],temp);
}
}
执行的结果如下:
排序好的数组比较经常的一项应用就是查找。这里来介绍一下折半查找:
假定n=1
您可能关注的文档
- 2019春长春版小学语文六年级下册全册教案.doc
- 2019春长春版语文一下《东西南北》word教案.doc
- 2019春长春版语文一下《古井》word教案.doc
- 2019春长春版语文一下《听声》word教案.doc
- 2019春长春版语文一下《夏日》word教案.doc
- 2019春长春版语文一下《山行》word教案.doc
- 2015年甘肃省一万名考试公共基础知识之时政[2月] [7].doc
- 迪斯尼电影年度代表.docx
- 2019春长春版语文一下《手捧空花盆的孩子》word教案.doc
- 2013别克AUTOPARK执行模版[2].ppt
- 2019春青岛版数学一下第四单元《牧童 认识图形》word教案1.doc
- 2019春青岛版数学三下第二单元《热闹的民俗节 对称》word单元教案.doc
- 2019春青岛版数学三下第八单元《谁长得快 数据的收集与整理二》word教案1.doc
- 2013高考数学[苏教版]专题通关必备知识点整合:X4-1-1几何证明选讲《第一节相似三角形的判定及性质》.ppt
- 2019春青岛版数学二下第一单元《游览北京 万以内数的认识》word教案.doc
- 2019春青岛版数学二下第一单元《野营 有余数的除法》word单元备课.doc
- 透析室工作规章制度.doc
- 2019春青岛版数学二下第七单元《快乐大课间 两位数乘一位数》word单元备课.doc
- 透水地坪露骨料施工组织的方案.doc
- 2019春青岛版数学二下第七单元《快乐大课间 两位数乘一位数》word教学设计.doc
文档评论(0)