C语言 桶排序

简介: 本文目录1. 简介2. 代码

1. 简介

作为快到没朋友的桶排序,还是需要介绍一下,虽然应用场景有限,但是一旦用上还是很牛X的。


桶排序的原理也很简单,假设有1-100范围内的数字,我们先准备100个桶贴上1-100的标签,然后出现那个数字就放到对应桶里面,最后按照桶的顺序输出即可。


我试了下,BUCKETSORT_MAX_NUM为250000时,程序还能跑。当BUCKETSORT_MAX_NUM达到260000,就报错了。我的电脑是4G内存的,不知道2G内存的和8G内存的同学能达到多少。不过一般250000也够用了。


2. 代码

//桶排序示例
#include<stdio.h>
//桶排序最大数字
#define BUCKETSORT_MAX_NUM 1000
//桶排序 p待排序数组指针 length数组长度
int bucketSort(int *p,int length)
{
  int i,j;
  int bucket[BUCKETSORT_MAX_NUM];
  //初始化
  for(i=0;i<BUCKETSORT_MAX_NUM;i++)
  {
    bucket[i]=0;
  }
  //桶排序
  for(i=0;i<length;i++)
  {
    bucket[p[i]]++;
  }
  //输出
  for(i=0;i<BUCKETSORT_MAX_NUM;i++)
  {
    for(j=0;j<bucket[i];j++)
    {
      printf("%d ",i);
    }
  }
  return 1;
}
int main()
{
  //待排序数组
  int array[10]={1,3,5,2,4,6,10,9,8,9}; 
  int sortResult=bucketSort(array,10);
  printf("\n%d",sortResult);
  return 1;
}
相关文章
|
存储 搜索推荐 算法
C语言算法--桶排序
什么是桶排序法?其实说白了就是把需要排列的元素分到不同的桶中,然后我们对这些桶里的元素进行排序的一种方式,然后我们在根据桶的顺序进行元素的合并。(不过前提是要确定桶的数量以及大小)
|
18天前
|
C语言 C++
C语言 之 内存函数
C语言 之 内存函数
30 3
|
9天前
|
存储 缓存 C语言
【c语言】简单的算术操作符、输入输出函数
本文介绍了C语言中的算术操作符、赋值操作符、单目操作符以及输入输出函数 `printf` 和 `scanf` 的基本用法。算术操作符包括加、减、乘、除和求余,其中除法和求余运算有特殊规则。赋值操作符用于给变量赋值,并支持复合赋值。单目操作符包括自增自减、正负号和强制类型转换。输入输出函数 `printf` 和 `scanf` 用于格式化输入和输出,支持多种占位符和格式控制。通过示例代码详细解释了这些操作符和函数的使用方法。
27 10
|
2天前
|
存储 算法 程序员
C语言:库函数
C语言的库函数是预定义的函数,用于执行常见的编程任务,如输入输出、字符串处理、数学运算等。使用库函数可以简化编程工作,提高开发效率。C标准库提供了丰富的函数,满足各种需求。
|
8天前
|
机器学习/深度学习 C语言
【c语言】一篇文章搞懂函数递归
本文详细介绍了函数递归的概念、思想及其限制条件,并通过求阶乘、打印整数每一位和求斐波那契数等实例,展示了递归的应用。递归的核心在于将大问题分解为小问题,但需注意递归可能导致效率低下和栈溢出的问题。文章最后总结了递归的优缺点,提醒读者在实际编程中合理使用递归。
32 7
|
8天前
|
存储 编译器 程序员
【c语言】函数
本文介绍了C语言中函数的基本概念,包括库函数和自定义函数的定义、使用及示例。库函数如`printf`和`scanf`,通过包含相应的头文件即可使用。自定义函数需指定返回类型、函数名、形式参数等。文中还探讨了函数的调用、形参与实参的区别、return语句的用法、函数嵌套调用、链式访问以及static关键字对变量和函数的影响,强调了static如何改变变量的生命周期和作用域,以及函数的可见性。
21 4
|
13天前
|
存储 编译器 C语言
C语言函数的定义与函数的声明的区别
C语言中,函数的定义包含函数的实现,即具体执行的代码块;而函数的声明仅描述函数的名称、返回类型和参数列表,用于告知编译器函数的存在,但不包含实现细节。声明通常放在头文件中,定义则在源文件中。
|
19天前
|
C语言
c语言回顾-函数递归(上)
c语言回顾-函数递归(上)
29 2
|
21天前
|
Java 编译器 C语言
【一步一步了解Java系列】:Java中的方法对标C语言中的函数
【一步一步了解Java系列】:Java中的方法对标C语言中的函数
18 3
|
24天前
|
存储 程序员 编译器
C语言——动态内存管理与内存操作函数
C语言——动态内存管理与内存操作函数