C语言:冒泡排序法

       此题的解决思路为:对于一组数字的排序,我们通过循环比较两个相邻元素的大小,若为升序排列则将最大值替换到最后。这样依次类推进行多趟冒泡排序即可将这组数字升序排列。

       例如:10,9,8,7,6,5,4,3,2,1

       通过一趟冒泡排序,我们将10置于最后一位。(9,8,7,6,5,4,3,2,1,10)

       第二趟冒泡排序我们将9置于倒数第二位。(8,7,6,5,4,3,2,1,9,10)

       以此类推,每次需要判断交换两元素的次数减少1。

       具体代码如下:

#include <stdio.h>
#include <stdlib.h>
void bubble_sort(int arr[], int sz)
{
	int i = 0;
	for (i = 0; i <= sz - 1; i++)//确定冒泡排序的趟数(10个元素走9趟)
	{
		//每一趟的比较和交换
		int j = 0;
		for (j = 0; j < sz - 1 - i; j++)
		{
			if (arr[j]>arr[j + 1])//若前一个元素大于后一个元素则交换两元素的值
			{
				int tmp = arr[j];
				arr[j] = arr[j + 1];
				arr[j + 1] = tmp;
			}
		}
	}
}
void print(int arr[], int sz)
{
	int i = 0;
	for (i = 0; i < sz; i++)
	{
		printf("%d ", arr[i]);
	}
	printf("\n");
}
int main()
{
	int arr[10] = { 10,9,8,7,6,5,4,3,2,1 };
	int sz = sizeof(arr) / sizeof(arr[0]);
	print(arr, sz);
	bubble_sort(arr, sz);
	print(arr, sz);
	system("pause");
	return 0;
}

       基于此代码我们还可以进行优化。

       我们考虑到若一组数据部分有序,在进行若干趟冒泡排序的过程中,没有任何一组两个元素交换时,说明数组已经排列完成,因此可以停止冒泡排序。这样可以提高程序的效率。

      此时我们引入一个flag变量,并初始化为0,只要在趟数中有元素交换我们则令flag为1,若当有一趟冒泡排序没有元素交换时,flag仍为0,此时加入判断停止条件即可。

       例如:10,1,2,3,4,5,6,7,8,9---->此时我们只需要进行一趟冒泡排序

       优化代码如下:

#include <stdio.h>
#include <stdlib.h>
void bubble_sort(int arr[], int sz)
{
	int i = 0;
	int flag = 0;
	for (i = 0; i <= sz - 1; i++)//确定冒泡排序的趟数(10个元素走9趟)
	{
		int j = 0;
		flag = 0;
		for (j = 0; j < sz - 1 - i; j++)
		{
			if (arr[j]>arr[j + 1])//若前一个元素大于后一个元素则交换两元素的值
			{
				int tmp = arr[j];
				arr[j] = arr[j + 1];
				arr[j + 1] = tmp;
				flag = 1;
			}
		}
		if (flag == 0)//没有元素交换时,则停止冒泡排序
			break;
	}
}
void print(int arr[], int sz)
{
	int i = 0;
	for (i = 0; i < sz; i++)
	{
		printf("%d ", arr[i]);
	}
	printf("\n");
}
int main()
{
	int arr[10] = { 10,1,2,3,4,5,6,7,8,9 };
	int sz = sizeof(arr) / sizeof(arr[0]);
	print(arr, sz);
	bubble_sort(arr, sz);
	print(arr, sz);
	system("pause");
	return 0;
}

       

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值