冒泡排序法

#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>

void sort(int arr[], int sz)
{
	int i = 0;
	for (i = 0; i < sz - 1; i++)
	{
		int flag = 1;//假设此趟排序的数据已经有序
		//确定冒泡排序的趟数
		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;
				flag = 0;//本趟排序不完全有序
			}
		}
		if (flag == 0)
		{
			break;
		}
	}
}

int main()
{
	int arr[] = { 5,8,2,7,3,6,9,4 };
	int i = 0;
	int sz = sizeof(arr) / sizeof(arr[0]);
	sort(arr, sz);
	for (i = 0; i < sz; i++)
	{
		printf("%d ", arr[i]);
	}
	return 0;
}

上一篇:迅为4412开发板源码分析之协处理器


下一篇:第一章uboot理论详解