原题链接:C语言训练-排序问题(1)
计数排序:不用交换,按数组下标排,只能排整数
#include #include int a[1000]={-1};//a数组存放正数 int b[1000]={-1};//b数组存放负数 int main() { //让数组下标和数组存放的值一一对应,遍历数组就可以做到排序 int i; while(scanf("%d",&i)!=EOF){ if(i>=0) a[i]=i;//如果输入大于等于0,存放到a数组 else b[abs(i)]=i;//如果输入小于0,存放到b数组 } for(int j=1000;j>0;j--){//遍历数组,负数升序输出 if(abs(b[j])==j){ printf("%d ",b[j]); } } for(int j=0;j<1000;j++){//遍历数组,正数升序输出 if(a[j]==j){ printf("%d ",a[j]); } } return 0; }
选择排序:每次把当前最小值换到前面,大交换
#include int main() { int a[10],i,j,m,t; for(i=0;i<10;i++){ scanf("%d",&a[i]); //输入10个数,无序区 } for(i=0;i<10;i++){//无序区 m=i; //假设最小值m是无序区第一个数 for(j=i+1;ja[j]){ m=j; } } if(m!=i){//如果最小值不是无序区第一个数,就把最小值和无序区第一个数交换 t=a[m]; a[m]=a[i]; a[i]=t; } //每次前面数和最小值互换,把当前最小值换到前面 } for(i=0;i<10;i++){ printf("%d ",a[i]); } return 0; }
冒泡排序:相邻比较交换,小交换
#include int main() { int a[10],i,j,t; for(i=0;i<10;i++){ scanf("%d",&a[i]); } for(i=1;i<10;i++){ for(j=0;ja[j+1]){ t=a[j]; a[j]=a[j+1]; a[j+1]=t; } } } for(i=0;i<10;i++){ printf("%d ",a[i]); } return 0; }
0.0分
4 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复