zoukankan      html  css  js  c++  java
  • 快速排序(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];
            }

        }

  • 相关阅读:
    事件处理之跨浏览器
    IE事件处理
    DOM0级事件处理、DOM2级事件处理
    JS内置对象学习总结
    JS事件响应的学习总结
    vuex的学习例子
    npm run build 打包后,如何运行在本地查看效果(Apache服务)
    Vue.js 引入外部js方法
    Table展开行
    正则表达式test()和exec()、 search() 和 replace()用法实例
  • 原文地址:https://www.cnblogs.com/skywind/p/1131612.html
Copyright © 2011-2022 走看看