计数排序:不用交换,按数组下标排,只能排整数

#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.0分

4 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 0 条评论

暂无评论