排序算法 c#实现

        上学的时候学算法,大体是知道了排序的工作原理,昨天写程序了突然发现原来明白和会写差很远,所以自己动手再写一次,我感觉快速排序的算法比冒泡和选择等的算法稍难以理解一点,不知道是我智商太低还是才疏学浅,把我写的快速排序方法,贴上来,仅供记忆。
        /// <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;
        }

转载于:https://www.cnblogs.com/raylovelc/archive/2008/01/22/1048468.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值