快速排序(QuickSort)用C# 实现的小例子

     class  QuickSort
    
{
        
public void Sort(int[] data, int start, int end)
        
{
            
if (start >= end) return;
            
if (start + 1 == end)
            
{
                
if (data[start] > data[end])
                    Swap(data, start, end);

                
return;
            }


            
int indexL = start + 1, indexR = end;
            
while (indexL < indexR)
            
{
                
// Get from left
                while (indexL <= end && data[start] >= data[indexL])
                    indexL
++;

                
// Get from right
                while (indexR > start && data[start] < data[indexR])
                    indexR
--;

                
if (indexL < indexR)
                
{
                    Swap(data, indexR, indexL);
                }

            }


            
if(indexL-1 !=start)
                Swap(data, start, indexL 
- 1);


            Sort(data, start, indexL 
- 2);
            Sort(data, indexL, end);
        }


        
private void Swap(int[] data, int x, int y)
        
{
            data[x] 
= data[x] + data[y];
            data[y] 
= data[x] - data[y];
            data[x] 
= data[x] - data[y];
        }

    }

本文转自Jack Niu博客园博客,原文链接:http://www.cnblogs.com/skywind/archive/2008/03/31/1131612.html,如需转载请自行联系原作者
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值