原题链接: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、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复