• 技术文章 >后端开发 >C#.Net教程

    排序算法测试程序入口

    黄舟黄舟2017-02-09 16:25:37原创860
    排序算法测试程序入口

    using System;
    using System.Collections.Generic;
    using System.Linq;
    using System.Text;
    using System.Collections;
    using System.Diagnostics;
    namespace Sort
    {
        class Program
        {
            static void Main(string[] args)
            {
                //Test(5);
                EfficiencyTest(100000,10,"BubbleSorter");          
            }
            //<生成随机数GenerateRandomNumber>
            public static List<int> GenerateRandomNumber(int Length)
            {
                List<int> newRandom = new List<int>();
                Random rd = new Random();
                for (int i = 0; i < Length; i++)
                {
                    newRandom.Add(rd.Next());
                }
                return newRandom;
            }
            //测试排序算法的正确性
            private static void Test(int n)
            {
                int[] de = GenerateRandomNumber(n).ToArray();
                Console.WriteLine("排序前:");
                foreach (int dee in de)
                {
                    Console.WriteLine(dee);
                }
                //int[] d = MergeSorter.Sort(de);
                //int[] d=HeapSorter.Sort(de);
                //int[] d = ShellSorter.Sort(de);
                //int[] d = InsertSorter.Sort(de);
                //int[] d = SelectSorter.Sort(de);
                //int[] d = CockTailSorter.Sort(de);
                int[] d = BubbleSorter.Sort(de);
                Console.WriteLine("排序后:");
                foreach (int dee in d)
                {
                    Console.WriteLine(dee);
                }
                //Console.ReadKey();
            }
            //测试各个排序算法效率
    	//调用Name函数排序i个数j次
            private static void EfficiencyTest(int i,int j,string Name)
            {
                double AverageTime = 0; ;
                string Cname = null;
                for (int n = 0; n < j;n++)
                {              
                    int[] de = GenerateRandomNumber(i).ToArray();
                    Stopwatch stopwatch = new Stopwatch();
                    stopwatch.Start();
                    DateTime dateStart = DateTime.Now;
                    switch(Name)
                    {
                        case "MergeSorter":
                            MergeSorter.Sort(de);
                            Cname = "MergeSorter";
                            break;
                        case "HeapSorter":
                            HeapSorter.Sort(de);
                            Cname = "HeapSorter";
                            break;
                        case "ShellSorter":
                            ShellSorter.Sort(de);
                            Cname = "ShellSorter";
                            break;
                        case "InsertSorter":
                            InsertSorter.Sort(de);
                            Cname = "InsertSorter";
                            break;
                        case "SelectSorter":
                            SelectSorter.Sort(de);
                            Cname = "SelectSorter";
                            break;
                        case "CockTailSorter":
                            CockTailSorter.Sort(de);
                            Cname = "CockTailSorter";
                            break;
                        case "BubbleSorter":
                            BubbleSorter.Sort(de);
                            Cname = "BubbleSorter";
                            break;
                        case "QuickSorter":
                            QuickSorter.Sort(de);
                            Cname = "QuickSorter";
                            break;
                    }
                    stopwatch.Stop();
                    AverageTime = (DateTime.Now - dateStart).TotalMilliseconds;        
                }
                Double span = AverageTime / j;
                Console.WriteLine(Cname + "排序" + i + "个数" + j + "次所用平均时间为:" + span + " 毫秒");
                Console.ReadKey();
            }
        }
    }

    以上就是 排序算法测试程序入口的内容,更多相关内容请关注PHP中文网(m.sbmmt.com)!


    php入门到就业线上直播课:查看学习

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。

    前端(VUE)零基础到就业课程:点击学习

    清晰的学习路线+老师随时辅导答疑

    自己动手写 PHP MVC 框架:点击学习

    快速了解MVC架构、了解框架底层运行原理

    上一篇: C# 冒泡排序 下一篇:自己动手写 PHP MVC 框架(40节精讲/巨细/新人进阶必看)

    相关文章推荐

    • ❤️‍🔥共22门课程,总价3725元,会员免费学• ❤️‍🔥接口自动化测试不想写代码?• c语言中源文件编译后生成什么文件• c语言标识符有哪些类型• asp.net 图片验证码的HtmlHelper• 解决asp.net中“从客户端中检测到有潜在危险的Request.Form值”的错误• C#中GDI+编程10个基本技巧二
    1/1

    PHP中文网