0
点赞
收藏
分享

微信扫一扫

目前很火的养猫微信小程序源码带流量主+搭建教程

12a597c01003 2023-09-27 阅读 14

在这里插入图片描述

文章目录

一、冒泡排序

1.原理:

2.流程图:

在这里插入图片描述

3.代码:

//冒泡排序
int* BubbleSort(int* a, int n)
{

	for (int i = 0; i < n - 1; i++)
	{
		for (int j = 0; j < n - i - 1; j++)
		{
			if (a[j + 1] < a[j])
			{
				int tmp = a[j + 1];
				a[j + 1] = a[j];
				a[j] = tmp;
			}
		}
	}
	return a;
}

4.测试结果:

在这里插入图片描述

5.时间复杂度

O(N^2)

二、选择排序

1.原理:

2.流程图:

此流程图是在遍历时只找最小值的方法;
而我们选择优化这个排序,通过在遍历时同时寻找最大值和最小值,来提升排序效率。
在这里插入图片描述

3.代码:

//选择排序
void SlectSort(int* a, int n)
{
	int begin = 0;
	int end = n - 1;
	while(begin<end)
	{
		int max = begin;
		int min = begin;
		for (int i = begin+1; i <= end; i++)
		{
			if (a[min] > a[i])
			{
				min = i;
			}
			if (a[max] < a[i])
			{
				max = i;
			}
		} 
		//先交换最小值到左边,
		Swap(&a[begin], &a[min]);
		//特殊情况。如果max在beain位置,会造成排序错误
		if (begin == max)
		{
			max = min;
		}
		//在交换最大值到右边
		Swap(&a[end], &a[max]);
		begin++;
		end--;
	}
}

4.测试结果:

在这里插入图片描述

5.时间复杂度

O(N^2)

三、直接插入排序

1.原理:

2.流程图:

在这里插入图片描述

3.代码:

//直接插入排序
int* InsetSort(int* a, int n)
{
	for (int i = 0; i < n - 1; i++)
	{
		int end = i;
		int tmp = a[end + 1];
		while (end >= 0)
		{
			if (tmp < a[end])
			{
				a[end + 1] = a[end];
			}
			else
			{
				break;
			}
			end--;
		}
		a[end + 1] = tmp;
	}
	return a;
}

4.测试结果:

在这里插入图片描述

5.时间复杂度

O(N^2)

举报

相关推荐

0 条评论