选择排序和冒泡排序的C和C的实现(总结).doc_第1页
选择排序和冒泡排序的C和C的实现(总结).doc_第2页
选择排序和冒泡排序的C和C的实现(总结).doc_第3页
全文预览已结束

VIP免费下载

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

C选择排序:#include #define N 10 main() int i,j,min,tmp,aN; /*input data*/ printf(please input ten num:n); for(i=0;iN;i+) printf(a%d=,i); scanf(%d,&ai); printf(n); for(i=0;iN;i+) printf(%d;,ai); printf(n); /*sort ten num*/ for(i=0;iN-1;i+) min = i; for(j+1; jaj) min =j; /记下最小元素的下标。 /*交换元素*/ key = ai; ai = amin; amin = key; /*output data*/ printf(After sorted n); for(i=0;iN;i+) printf(%d;,ai); C冒泡排序:#define n 10void main() int xn,i; printf(请输入%d个整数:,n); for(i=0;i0; h=k) /*循环到没有比较范围*/ for (j=0, k=0; j *(x+j+1) /*大的放在后面,小的放到前面*/ t = *(x+j); *(x+j) = *(x+j+1); *(x+j+1) = t; /*完成交换*/ k = j; /*保存最后下沉的位置。这样k后面的都是排序排好了的。*/ printf(n排序后的顺序为:n); for(i=0;in;i+) printf(%d ,xi);C+选择排序:#includeusing namespace std; int main() int num10 = 9,8,10,3,4,6,4,7,2,1; cout排序前:endl; for (int m = 0;m 10;m+) coutnumm ; for (int i = 0;i 10;i+) int pos = i; for (int j = i;j numj) pos = j; int tem; tem = numpos; numpos = numi; numi = tem; coutendl排序后:endl; for (int m = 0;m 10;m+) coutnumm ; return 0; /*选择排序法的第一层循环从起始元素开始选到倒数第二个元素,主要是在每次进入的第二层循环之前,将外层循环的下标赋值给临时变量,接下来的第二层循环中,如果发现有比这个最小位置处的元素更小的元素,则将那个更小的元素的下标赋给临时变量,最后,在二层循环退出后,如果临时变量改变,则说明,有比当前外层循环位置更小的元素,需要将这两个元素交换.*/C+冒泡排序:#include #define LEN 10 using namespace std; int main() int nArrayLEN; for(int i=0;iLEN;i+) nArrayi=LEN-i; cout原始数据为:endl; for(int i=0;iLEN;i+) coutnArrayi ; cout0;i-) for(int j=0;jnArrayj+1) temp=nArrayj; nArrayj=nArrayj+1; nArrayj+

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论