• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

排序算法 c#实现

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

        上学的时候学算法,大体是知道了排序的工作原理,昨天写程序了突然发现原来明白和会写差很远,所以自己动手再写一次,我感觉快速排序的算法比冒泡和选择等的算法稍难以理解一点,不知道是我智商太低还是才疏学浅,把我写的快速排序方法,贴上来,仅供记忆。
        /// <summary>
        /// 快速排序算法
        /// </summary>
        /// <param name="array">待排序数组</param>
        /// <param name="low">起始位置</param>
        /// <param name="high">结束位置</param>
        public void QuickSort(int[] array, int low, int high)
        {           
            int pivot=array[low];            //支点,比较大小用。
            int left, right;       
            int temp;      //临时变量,记录比较到哪里完成了一轮交换
            left = low;
            right = high;

            if (low >= high)
            {
                return;
            }
            else{
                while (true) {
                    while (array[right] > pivot)           
                    {
                        right--;
                    }
                    while (array[left] < pivot)
                    {
                        left++;
                    }
                    if (left>=right)
                    {
                        temp=left;
                        break;
                    }
                    else
                    {
                        Swap(ref array[left], ref array[right]);
                    }
                }
                int length = array.Length;       //下边把每轮交换后的结果显示出来,看看快速排序是如何工作的
                for (int i = 0; i < length; i++)
                {
                    Console.Write("array[" + i.ToString() + "]=" + array[i].ToString()+";");
                }
                Console.WriteLine();
                QuickSort(array,low,temp-1);           /对分割完的数组继续调用自己,直到数组只有一个元素为止。
                QuickSort(array,temp+1,high);
            }
        }

        /// <summary>
        /// 交换两个数的值
        /// </summary>
        /// <param name="i"></param>
        /// <param name="j"></param>
        public void Swap(ref int i, ref int j)  
        {
            int s;
            s = j;
            j = i;
            i = s;
        }


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
C#DragDropEffects类与拖动实现发布时间:2022-07-13
下一篇:
C#的空接合运算符三目运算符发布时间:2022-07-13
热门推荐
热门话题
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap