关于基础算法排序————“桶排序”入门题详细解析

一.桶排序 顾名思义,桶排序就是创建出空间像桶一样把数据转入其中来进行统计,然后每装一次标记就加一,最后按照标记数量来有序输出,即可达到排序效果。


这是一个简单地例子:将以下10个数进行排序:7 8 3 6 4 2 9 5 8 1

可以看见这几个书都是处于乱序状态

不多说,看代码

#include<stdio.h>

int main()
{
	int n;//创建一个容纳数字的量
	int arr[10] = { 0 };//必须要初始化,要不然将无法运行'标记加一'操作
	for (int i = 0; i < 10; i++)
	{
		scanf("%d", &n);//引入数字      
		arr[n]++;//将其放入对应桶里
	}
	for (int i = 0; i < 10; i++)//这里是从小到大,如果想从大到小将i初始化为9然后递减到0即可
	{
		for(int j=arr[i];j>0;j--)//将桶里面的数依次拿出即可
		{
			printf("%d ", i);//拿出打印
		}
	}
	return 0;
}

可以看见,桶排序的时间复杂的很小,仅仅只有两个for循环,但是当其要求的排序的数据越来越大时,‘桶’的数量就越来越多,所以在空间上是劣势。

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值