【竞赛】排序算法的最快实现

 【竞赛】排序算法的最快实现

 

C# code
using System;

namespace ConsoleApplication1
{
    class Program
    {
        static int MaxRange = 20080623;
        static void Main(string[] args)
        {
            Test(10*10000);
            Console.Read();
            Test(100*10000);
            Console.Read();
            Test(1000*10000);
            Console.Read();
        }
        public static void Test(int MAX)
        {         
            int[] nums = new int[MAX];
            Random r = new Random(MaxRange);
            for (int i = 0; i < MAX; i++)
            {
                nums[i] = r.Next(MAX);
            }
            long begin = System.DateTime.Now.Ticks;
            Sort(nums);
            long end = System.DateTime.Now.Ticks;
            Console.WriteLine("总共" + MAX/10000 + "万数据,用时" + System.TimeSpan.FromTicks(end - begin).Milliseconds + "豪秒");         
        }

        public static void Sort(int[] a)
        {

            int[] p = new int[MaxRange + 1]; 

            for (int i = 0; i <a.Length; i++)
            {
              p[a[i]]++;
            }
            for (int i = 0, j = 0; i <= MaxRange; i++)
            {
                while (p[i] > 0)
                {
                    a[j++] = i;
                    p[i]--;
                }
            }
           
        }
    }
}

评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值