新书推介:《语义网技术体系》
作者:瞿裕忠,胡伟,程龚
   XML论坛     W3CHINA.ORG讨论区     计算机科学论坛     SOAChina论坛     Blog     开放翻译计划     新浪微博  
 
  • 首页
  • 登录
  • 注册
  • 软件下载
  • 资料下载
  • 核心成员
  • 帮助
  •   Add to Google

    >> 本版讨论.NET,C#,ASP,VB技术
    [返回] 中文XML论坛 - 专业的XML技术讨论区计算机技术与应用『 Dot NET,C#,ASP,VB 』 → 快速排序算法的C#实现 查看新帖用户列表

      发表一个新主题  发表一个新投票  回复主题  (订阅本版) 您是本帖的第 3230 个阅读者浏览上一篇主题  刷新本主题   树形显示贴子 浏览下一篇主题
     * 贴子主题: 快速排序算法的C#实现 举报  打印  推荐  IE收藏夹 
       本主题类别:     
     admin 帅哥哟,离线,有人找我吗?
      
      
      
      威望:9
      头衔:W3China站长
      等级:计算机硕士学位(管理员)
      文章:5255
      积分:18406
      门派:W3CHINA.ORG
      注册:2003/10/5

    姓名:(无权查看)
    城市:(无权查看)
    院校:(无权查看)
    给admin发送一个短消息 把admin加入好友 查看admin的个人资料 搜索admin在『 Dot NET,C#,ASP,VB 』的所有贴子 点击这里发送电邮给admin  访问admin的主页 引用回复这个贴子 回复这个贴子 查看admin的博客楼主
    发贴心情 快速排序算法的C#实现


    发信人: Jobs (温少), 信区: DotNET        
    标  题: 快速排序算法的C#实现
    发信站: BBS 水木清华站 (Sun Jan  5 02:48:33 2003)

    /**
    *  
    *  

        @author     <a href="wen">mailto:szuJobs@hotmail.com">wenshaojin</a>
        @created    January 5, 2003
        @version    1

    *
    **/
    using System;
    using System.Collections;

    namespace Matrix.Common.Utils
    {
        /// <summary>
        /// Summary description for SortUtils.
        /// </summary>
        public class SortUtils
        {
            #region 用于IList的快速排序
            /// <summary>
            /// 快速排序
            /// </summary>
            /// <param name="array"></param>
            public static void QuickSort(IList list)
            {
                QuickSort(list, 0, list.Count-1, new CompareMethod(Comparer.Defaul
    t.Compare));
            }

            public static void QuickSort(IList list, CompareMethod compare)
            {
                QuickSort(list, 0, list.Count-1, compare);
            }

            private static void QuickSort(IList list, int low, int high, CompareMe
    thod compare)
            {
                if(low >= high)
                {
                    return;
                }

                int i = low; //从左到右的游标
                int j = high + 1; //从右到左的游标

                object pivot = list[low];

                //把左侧>=pivot的元素与右侧<=pivot的元素进行交换
                while(true)
                {
                     
                    do //从左侧寻找>=pivot的元素
                    {
                        i++;
                    }
                    while(compare(list[i], pivot)<0);

                    do //从右侧寻找<=pivot的元素
                    {
                        j--;
                    }
                    while(compare(list[j], pivot)>0);

                    if(i >= j) //未发现交换对象
                    {
                        break;
                    }

                    //Swap
                    object temp = list[i];
                    list[i] = list[j];
                    list[j] = temp;
                }

                //设置pivot
                list[low] = list[j];
                list[j] = pivot;

                QuickSort(list, low, j-1, compare); //对左段排序
                QuickSort(list, j+1, high, compare); //对右段排序
            }

            #endregion

            //用于值类型的快速排序,有更好的性能
            #region 用于值类型数组的快速排序
            /// <summary>
            /// 快速排序
            /// </summary>
            /// <param name="array"></param>
            public static void QuickSort(int[] array)
            {
                QuickSort(array, 0, array.Length-1);
            }

            /// <summary>
            /// 快速排序
            /// </summary>
            /// <param name="array"></param>
            public static void QuickSort(long[] array)
            {
                QuickSort(array, 0, array.Length-1);
            }

            /// <summary>
            /// 快速排序
            /// </summary>
            /// <param name="array"></param>
            public static void QuickSort(float[] array)
            {
                QuickSort(array, 0, array.Length-1);
            }

            /// <summary>
            /// 快速排序
            /// </summary>
            /// <param name="array"></param>
            public static void QuickSort(double[] array)
            {
                QuickSort(array, 0, array.Length-1);
            }

            /// <summary>
            /// 快速排序
            /// </summary>
            /// <param name="array"></param>
            public static void QuickSort(decimal[] array)
            {
                QuickSort(array, 0, array.Length-1);
            }

            /// <summary>
            /// 快速排序
            /// </summary>
            /// <param name="array"></param>
            public static void QuickSort(DateTime[] array)
            {
                QuickSort(array, 0, array.Length-1);
            }


            private static void QuickSort(int[] array, int low, int high)
            {
                if(low >= high)
                {
                    return;
                }

                int i = low; //从左到右的游标
                int j = high + 1; //从右到左的游标

                int pivot = array[low];

                //把左侧>=pivot的元素与右侧<=pivot的元素进行交换
                while(true)
                {
                    do //从左侧寻找>=pivot的元素
                    {
                        i++;
                    }
                    while(array[i] < pivot);

                    do //从右侧寻找<=pivot的元素
                    {
                        j--;
                    }
                    while(array[j] > pivot);

                    if(i >= j) //未发现交换对象
                    {
                        break;
                    }

                    Swap(ref array[i], ref array[j]);
                }

                //设置pivot
                array[low] = array[j];
                array[j] = pivot;

                QuickSort(array, low, j-1); //对左段排序
                QuickSort(array, j+1, high); //对右段排序
            }

            private static void QuickSort(long[] array, int low, int high)
            {
                if(low >= high)
                {
                    return;
                }

                int i = low; //从左到右的游标
                int j = high + 1; //从右到左的游标

                long pivot = array[low];

                //把左侧>=pivot的元素与右侧<=pivot的元素进行交换
                while(true)
                {
                    do //从左侧寻找>=pivot的元素
                    {
                        i++;
                    }
                    while(array[i] < pivot);

                    do //从右侧寻找<=pivot的元素
                    {
                        j--;
                    }
                    while(array[j] > pivot);

                    if(i >= j) //未发现交换对象
                    {
                        break;
                    }

                    Swap(ref array[i], ref array[j]);
                }

                //设置pivot
                array[low] = array[j];
                array[j] = pivot;

                QuickSort(array, low, j-1); //对左段排序
                QuickSort(array, j+1, high); //对右段排序
            }

            private static void QuickSort(float[] array, int low, int high)
            {
                if(low >= high)
                {
                    return;
                }

                int i = low; //从左到右的游标
                int j = high + 1; //从右到左的游标

                float pivot = array[low];

                //把左侧>=pivot的元素与右侧<=pivot的元素进行交换
                while(true)
                {
                    do //从左侧寻找>=pivot的元素
                    {
                        i++;
                    }
                    while(array[i] < pivot);

                    do //从右侧寻找<=pivot的元素
                    {
                        j--;
                    }
                    while(array[j] > pivot);

                    if(i >= j) //未发现交换对象
                    {
                        break;
                    }

                    Swap(ref array[i], ref array[j]);
                }

                //设置pivot
                array[low] = array[j];
                array[j] = pivot;

                QuickSort(array, low, j-1); //对左段排序
                QuickSort(array, j+1, high); //对右段排序
            }

            private static void QuickSort(double[] array, int low, int high)
            {
                if(low >= high)
                {
                    return;
                }

                int i = low; //从左到右的游标
                int j = high + 1; //从右到左的游标

                double pivot = array[low];

                //把左侧>=pivot的元素与右侧<=pivot的元素进行交换
                while(true)
                {
                    do //从左侧寻找>=pivot的元素
                    {
                        i++;
                    }
                    while(array[i] < pivot);

                    do //从右侧寻找<=pivot的元素
                    {
                        j--;
                    }
                    while(array[j] > pivot);

                    if(i >= j) //未发现交换对象
                    {
                        break;
                    }

                    Swap(ref array[i], ref array[j]);
                }

                //设置pivot
                array[low] = array[j];
                array[j] = pivot;

                QuickSort(array, low, j-1); //对左段排序
                QuickSort(array, j+1, high); //对右段排序
            }

            private static void QuickSort(decimal[] array, int low, int high)
            {
                if(low >= high)
                {
                    return;
                }

                int i = low; //从左到右的游标
                int j = high + 1; //从右到左的游标

                decimal pivot = array[low];

                //把左侧>=pivot的元素与右侧<=pivot的元素进行交换
                while(true)
                {
                    do //从左侧寻找>=pivot的元素
                    {
                        i++;
                    }
                    while(array[i] < pivot);

                    do //从右侧寻找<=pivot的元素
                    {
                        j--;
                    }
                    while(array[j] > pivot);

                    if(i >= j) //未发现交换对象
                    {
                        break;
                    }

                    Swap(ref array[i], ref array[j]);
                }

                //设置pivot
                array[low] = array[j];
                array[j] = pivot;

                QuickSort(array, low, j-1); //对左段排序
                QuickSort(array, j+1, high); //对右段排序
            }

            private static void QuickSort(DateTime[] array, int low, int high)
            {
                if(low >= high)
                {
                    return;
                }

                int i = low; //从左到右的游标
                int j = high + 1; //从右到左的游标

                DateTime pivot = array[low];

                //把左侧>=pivot的元素与右侧<=pivot的元素进行交换
                while(true)
                {
                    do //从左侧寻找>=pivot的元素
                    {
                        i++;
                    }
                    while(array[i] < pivot);

                    do //从右侧寻找<=pivot的元素
                    {
                        j--;
                    }
                    while(array[j] > pivot);

                    if(i >= j) //未发现交换对象
                    {
                        break;
                    }

                    Swap(ref array[i], ref array[j]);
                }

                //设置pivot
                array[low] = array[j];
                array[j] = pivot;

                QuickSort(array, low, j-1); //对左段排序
                QuickSort(array, j+1, high); //对右段排序
            }


            private static void Swap(ref int a, ref int b)
            {
                int temp = a;
                a = b;
                b = temp;
            }
            private static void Swap(ref long a, ref long b)
            {
                long temp = a;
                a = b;
                b = temp;
            }
            private static void Swap(ref float a, ref float b)
            {
                float temp = a;
                a = b;
                b = temp;
            }
            private static void Swap(ref double a, ref double b)
            {
                double temp = a;
                a = b;
                b = temp;
            }
            private static void Swap(ref decimal a, ref decimal b)
            {
                decimal temp = a;
                a = b;
                b = temp;
            }
            private static void Swap(ref DateTime a, ref DateTime b)
            {
                DateTime temp = a;
                a = b;
                b = temp;
            }
            #endregion

            /// <summary>
            /// 如果a小于b,返回小于0的数字。
            /// 如果a等于b,返回等于0的数字。
            /// 如果a大于b,返回大于0的数字。
            /// </summary>
            public delegate int CompareMethod(object a, object b);
        }
    }


    --

    ※ 来源:·BBS 水木清华站 smth.org·[FROM: 218.17.71.167]
    上一篇
    返回上一页
    回到目录
    回到页首
    下一篇


       收藏   分享  
    顶(0)
      




    ----------------------------------------------

    -----------------------------------------------

    第十二章第一节《用ROR创建面向资源的服务》
    第十二章第二节《用Restlet创建面向资源的服务》
    第三章《REST式服务有什么不同》
    InfoQ SOA首席编辑胡键评《RESTful Web Services中文版》
    [InfoQ文章]解答有关REST的十点疑惑

    点击查看用户来源及管理<br>发贴IP:*.*.*.* 2004/11/9 2:25:00
     
     GoogleAdSense
      
      
      等级:大一新生
      文章:1
      积分:50
      门派:无门无派
      院校:未填写
      注册:2007-01-01
    给Google AdSense发送一个短消息 把Google AdSense加入好友 查看Google AdSense的个人资料 搜索Google AdSense在『 Dot NET,C#,ASP,VB 』的所有贴子 点击这里发送电邮给Google AdSense  访问Google AdSense的主页 引用回复这个贴子 回复这个贴子 查看Google AdSense的博客广告
    2024/5/10 13:32:08

    本主题贴数1,分页: [1]

    管理选项修改tag | 锁定 | 解锁 | 提升 | 删除 | 移动 | 固顶 | 总固顶 | 奖励 | 惩罚 | 发布公告
    W3C Contributing Supporter! W 3 C h i n a ( since 2003 ) 旗 下 站 点
    苏ICP备05006046号《全国人大常委会关于维护互联网安全的决定》《计算机信息网络国际联网安全保护管理办法》
    125.000ms