首页 > 代码库 > 【C#】1.算法温故而知新 - 简单的桶排序

【C#】1.算法温故而知新 - 简单的桶排序

缺点:

1.不适用于小数

2.当数值过多,太浪费空间,比如数值范围为0~99999,那需申请100000个变量,也就是要写成a[1000000]。

 

 

代码如下:

using System;using System.Collections.Generic;using System.Linq;using System.Text;namespace ConsoleApplication1{    public class Program    {        public static void Main(string[] args)        {            int[] nums = new int[9] { 2, 1, 9, 2, 7, 3, 1, 8, 2 };//初始化一个数组,其中有9个数,每个数都不大于10,这里假定是我们输入的数,需要从小到大排序            int[] a = new int[11];//因为每个数都不大于10,所以初始化一个包含11个数的数组a            int i, j, t;            for (i = 0; i <= 10; i++) a[i] = 0;//给a数组赋值都为0            for (i = 0; i < nums.Length; i++)            {                t = nums[i];//获取当前的数                a[t]++;//进行计数            }            for (i = 0; i <= 10; i++)//依次判断a[0]~a[10]                for (j = 1; j <=a[i]; j++)//出现了几次就输出几次                    Console.Write("  " + i);        }    }}

 

【C#】1.算法温故而知新 - 简单的桶排序