zoukankan      html  css  js  c++  java
  • c++实现快速排序详细分析

    快速排序坑挺多的,今天有空记录一下自己的实现,并加上详细的注释和举例

    #include<iostream>
    
    using namespace std;
    
    int partion(int num[],int left,int right)
    {
        int i,j,index,exchage;
        index = num[left];
        i = left; //由于while (i < j)已经决定了,如果 i = left + 1;而数组只有两个元素且j 指向的元素比较大,如 3 8 那么循环不会执行,最后还把8 和3交换了
        j = right;
        while (i<j) // 3 7 2 4 下面的sawp 执行后 变成 3 2 7 4 这时候 i 指向7 j指向2, 就不需要再循环了j就是最终位置  
        {
            while(num[i] <= index && i < right) // i < right 是为了处理 100 2 3 4 这样的情况,i 会一直扫描越界,为什么不是 i<= right,因为已经j 在right了,一定会处理那个元素
              i++;
        
            while(num[j] >= index && j > left) //j > left 是为了处理 -13 2 1 4 这样的情况,j 会一直扫描到-13的左边越界, 注意 j 是 > left, 不是>i 否则 3 8 这种情况就错了
                j--;
            
            if(i < j)
                swap(num[i++],num[j--]);//循环结束三种情况,第一种是 3 7 2 4 第二种是 3 3 1,i == right == j结束了,这时候 i j 肯定在一起,就没有必要交换了
    //第三种是 3 7 9 这时候j 因为越界判断失败而退出循环,为什么越界,因为它碰到了第一个元素,这时候不能交换3 和 7 ,因为i 停在了比第一个元素大的地方
        }
    
         swap(num[left],num[j]);// 从小到大排序注意是 交换 j 和 index 位置!
    
        return j;
    }
    void quick_sort(int num[],int lo,int hi)
    {
        if (lo<hi)
        {
            int x = partion(num,lo,hi); //对于 3 8 ,x = 0
            quick_sort(num,lo,x-1); //0 到 -1 所以要判断lo <= hi 如果是等于
            quick_sort(num,x+1,hi);//1 到 1,由于只有一个元素8,也没有必要排序了所以上面注释的lo <= hi改成 lo < hi
    
        }
    }
    int main()
    {
        int a[5] = {3, 4, 2, 1, 0 };
        quick_sort(a,0,4);
         for(i=0;i<5;i++)
             cout << a[i] << endl;
        return 0;
    }
  • 相关阅读:
    Python 双向链表的实现
    Python 单链表实现
    分享两种 Python 中的单例模式
    HTML 盒子模型
    HTML 行高
    HTML 超链接 文本修饰 背景属性
    HTML 标签分类
    HTML 文字,样式表
    HTML CSS
    HTML 锚点 空链 超链优化写法
  • 原文地址:https://www.cnblogs.com/yanchengwang/p/5990470.html
Copyright © 2011-2022 走看看