小白进阶之冒泡排序、归并排序、选择排序、冒泡排序

本文详细介绍了四种经典的排序算法:插入排序、归并排序、选择排序和冒泡排序。每种算法都通过代码实例进行了说明,包括它们的基本思想、实现方式及运行过程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

武汉一个阳光不算好不算坏的、丝毫没有夏意的夏日的周日写的四大排序算法。

1.插入排序

插入排序就像是给我们要排序的元素找一个合适的“坑”填进去一样。每一次都把元素与前面的元素比较,若是前面的元素比现在的元素大,则前面的元素下移,直到找到合适的“坑”。代码如下:

void insertionSort(int a[],int n){
	int i,j,key;
	for(j=1;j<10;j++){
		key=a[j];
		i=j-1;
		while(i>=0&&a[i]>key){
			a[i+1]=a[i];
			i=i-1;
		}
		a[i+1]=key;
	}
}

2.归并排序

归并排序用到了递归。基本思想是将要排序的数组从中间分为左右两个子数组,再递归对左右两个子数组进行排序,最后将排序好的左右子数组进行归并。归并的过程好像是在打扑克的前奏即取牌。首先取出最前面的两个,进行比较,小的那一边先放入数组,并取这一边的下一个数,再进行比较,直至两边均取至最大值(通常设置左右子数组的最后一个元素为无穷大)。代码如下:

void mergeSort(int a[],int p,int r){
	int q;
	if(p<r){
		q=(p+r)/2;	
		mergeSort(a,p,q);//递归
		mergeSort(a,q+1,r);
		merge(a,p,q,r);//合并
	}
}

void merge(int a[],int p,int q,int r){
	int i=0,j=0,k;
	int n1=q-p+1;
	int n2=r-q;
	int *L=(int *)malloc(sizeof(int)*(n1+1));
	int *R=(int *)malloc(sizeof(int)*(n2+1));
	for(i=0;i<n1;i++)
		L[i]=a[p+i];
	for(j=0;j<n2;j++)
		R[j]=a[q+j+1];
	L[n1]=INT_MAX;//int中的最大值,头文件为limits.h
	R[n2]=INT_MAX;
	i=0;
	j=0;
	for(k=p;k<=r;k++){
		if(L[i]<=R[j]){
			a[k]=L[i];
			i=i+1;
		}
		else{
			a[k]=R[j];
			j=j+1;
		}
	}
	free(L);
	free(R);
}

3.选择排序

选择排序的风格比较符合我的胃口。选择排序首先选出数组中最小的元素,将其放在第“1”个,然后依次选出第二小,第三小。。。放在第”2“个,第”3“个。。。。好任性的算法。代码如下:

void selectSort(int a[],int n){
	int i,key,k,j;
	for(i=0;i<n;i++){
		key=a[i];
		k=i;
		for(j=i;j<n;j++)
			if(a[j]<key){
				key=a[j];
				k=j;
			}
			a[k]=a[i];
			a[i]=key;
	}
}

4.冒泡排序

《算法导论》书上对冒泡排序算法的形容是流行但低效的排序算法。它的基本思想是反复交换没有排序好的算法,始终保持最前面的是最小的。毕竟是bubble,挺可爱的。嘿嘿。话不多说,上代码:

void bubbleSort(int a[],int n){
	int i,j,key;
	for(i=0;i<n-1;i++){
		for(j=n-1;j>i;j--){
			if(a[j]<a[j-1]){//交换a[j-1]和a[j]
				key=a[j-1];
				a[j-1]=a[j];
				a[j]=key;
			}
		}
	}
}

这就是今天的成果了,其实还看了一下MFC,等看的差不多再写MFC好了。

要有力气的活着~哈哈哈哈~

晚安~



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值