收藏 分销(赏)

快速排序的短发.doc

上传人:仙人****88 文档编号:8400454 上传时间:2025-02-11 格式:DOC 页数:3 大小:85.50KB 下载积分:10 金币
下载 相关 举报
快速排序的短发.doc_第1页
第1页 / 共3页
快速排序的短发.doc_第2页
第2页 / 共3页


点击查看更多>>
资源描述
编程工具:C-Free 5.0 【实验二】:快速排序 (一)快速排序.cpp #include<stdio.h> #include<stdlib.h> #define SIZE 100 void quick_sort(int data[],int x,int y); int pation(int data[],int x,int y); int main() { int i,n,data[SIZE]; printf("请输入要排列的数目(<=100):"); scanf("%d",&n); printf("请输入要排列的数列:\n"); for(i=0;i<n;++i) scanf("%d",&data[i]); quick_sort(data,0,n-1); printf("排列后的数列为:\n"); for(i=0;i<n;++i) printf( "%d ",data[i]); printf("\n"); return 0; } void quick_sort(int data[],int x,int y) { if(x>=y) return; int q=pation(data,x,y); quick_sort(data,x,q-1); quick_sort(data,q+1,y); } int pation(int data[],int x,int y) { int n=data[x],i=x+1,j=y,temp; while(1) { while(data[i]<n) ++i; while(data[j]>n) --j; if(i>=j) break; temp=data[i]; data[i]=data[j]; data[j]=temp; } data[x]=data[j]; data[j]=n; return j; } (二)插入排序.cpp #include<stdio.h> #include<conio.h> #define X 100 #define Y 100 int main() { int a[X],r[Y]; int *p; int i,j,n; printf("请输入要排列的数目(<=100):"); scanf("%d",&n); printf("请输入要排列的数列:\n"); for(i=0;i<n;i++) { p=&a[i]; scanf("%d",p); r[i+1]=a[i]; } r[0]=1; for(i=2;i<=n;i++) { r[0]=r[i]; j=i-1; while(r[j]>r[0]) { r[j+1]=r[j]; j--; } r[j+1]=r[0]; } printf("排列后的顺序是:\n"); for(i=1;i<=n;i++) { p=&r[i]; printf("%d ",*p); } printf("\n"); return 0; }
展开阅读全文

开通  VIP会员、SVIP会员  优惠大
下载10份以上建议开通VIP会员
下载20份以上建议开通SVIP会员


开通VIP      成为共赢上传

当前位置:首页 > 教育专区 > 小学其他

移动网页_全站_页脚广告1

关于我们      便捷服务       自信AI       AI导航        抽奖活动

©2010-2026 宁波自信网络信息技术有限公司  版权所有

客服电话:0574-28810668  投诉电话:18658249818

gongan.png浙公网安备33021202000488号   

icp.png浙ICP备2021020529号-1  |  浙B2-20240490  

关注我们 :微信公众号    抖音    微博    LOFTER 

客服