c语言冒泡排序

系列文章目录

c语言冒泡排序


c语言冒泡排序

  • 系列文章目录
  • 一、冒泡排序原理
  • 二、冒泡排序案例


一、冒泡排序原理


有几个数就需要排序几次-1


从数组第一个元素开始和相邻的元素比对,大的元素放在后面,小的放在前面
如,428057139
4与2对比,4大于2,4放在后面
变成248057139
然后4再和8对比,8比4大,位置不变248057139
8与0对比,8大,0和8位置交换,后面按照相同原理,依次交换完,找到最大值9
然后再重新从24057138找到最大的值,依次排序共8次

c语言冒泡排序_第1张图片


二、冒泡排序案例


int main()	
{	
	int arr[10] = { 1, 4, 6, 8, 3, 2, 7, 5, 10, 9 };
	int len = sizeof(arr) / sizeof(arr[0]) - 1;
	//总的排序次数为:数组大小-1,并且每次排序都能找到最大值
	for (int i = 0; i <= len; i++)
	{ //每次排序中,相邻的两个数组元素比较,大的元素放后面,小的元素放前面
	  //比较次数为:总的排序次数-第几次排序
		for (int j = 0; j < len - i; j++)
		{
			if (arr[j] > arr[j + 1])
			{
				int temp = arr[j];
				arr[j] = arr[j + 1];
				arr[j + 1] = temp;
			}
		}
	}
	for (int i = 0; i <= len; i++)
	{
		printf("%d\n", arr[i]);
	}
}

END
c语言冒泡排序_第2张图片

你可能感兴趣的:(c语言,c语言,排序算法,开发语言)