排序. 快速排序

作者: 周肃 | 来源:发表于2017-06-22 08:04 被阅读31次

以前写过一篇, 分析的非常详细.
排序算法(1) 快速排序 C++实现

引用了一个动图, 直观地感受快速排序过程.
演示的算法和实现稍有区别, 请仔细感受一下.

快速排序过程

实现

class Solution {
public:
    /**
     * @param A an integer array
     * @return void
     */
    void sortIntegers2(vector<int>& A) {
        // Write your code here
        if (A.size() == 0)
        {   
            return;
        }
        quicksort(A, 0, A.size() - 1);
    }
private:
    void quicksort(std::vector<int>& nums, int start, int end)
    {
        if (start >= end) return;

        int mid = partition(nums, start, end);
        if (mid - 1 > start)
        {
            quicksort(nums, start, mid - 1);
        }
        if (mid + 1 < end)
        {
            quicksort(nums, mid + 1, end);
        }
    }
    int partition(std::vector<int>& nums, int start, int end)
    {
        int pivot = nums[start];
        int left = start;
        for (int i = start + 1; i <= end; ++i)
        {
            if (nums[i] < pivot)
            {
                left++;
                swap(nums, left, i);
            }
        }
        swap(nums, left, start);
        return left;
    }
    int swap(std::vector<int>& nums, int i, int j)
    {
        int tmp = nums[i];
        nums[i] = nums[j];
        nums[j] = tmp;
    }
};

相关文章

  • 面试准备--排序

    堆排序 快速排序(simple) 快速排序(regular) 归并排序 Shell排序 插入排序 选择排序 冒泡排序

  • 排序

    插入排序 选择排序 冒泡排序 归并排序 快速排序* 三路快速排序

  • Datawhale | 编程第6期 Test 3

    排序 1.实现归并排序、快速排序、插入排序、冒泡排序、选择排序、堆排序(选做) 归并排序 快速排序 插入排序 冒泡...

  • 七大排序算法之快速排序

    七大排序算法之快速排序 @(算法笔记)[排序算法, 快速排序, C++实现] [TOC] 快速排序的介绍: 快速排...

  • 图形化排序算法比较:快速排序、插入排序、选择排序、冒泡排序

    图形化排序算法比较:快速排序、插入排序、选择排序、冒泡排序 图形化排序算法比较:快速排序、插入排序、选择排序、冒泡排序

  • OC数据结构&算法

    更多整理资料尽在?一平米小站 目录 选择排序 冒泡排序 插入排序 快速排序 双路快速排序 三路快速排序 堆排序 选...

  • 常见排序算法

    这里介绍四种排序算法,选择排序、快速排序、归并排序、计数排序 选择排序(使用递归) 选择排序(使用循环) 快速排序...

  • 排序算法

    冒泡排序 选择排序 插入排序二分插入排序希尔排序 堆排序 归并排序 快速排序 交换排序类:冒泡排序快速排序 选择排...

  • 算法笔记01-排序#2

    快速排序敢叫快速排序,那它一定得快。 快速排序 概述 快速排序也是分治排序的典型,它快,而且是原地排序。不过,要防...

  • php-归并排序、快速排序、堆排序

    归并排序、快速排序、堆排序 时间复杂度 O(nlogn) 归并排序 快速排序(快排) 堆排序

网友评论

    本文标题:排序. 快速排序

    本文链接:https://www.haomeiwen.com/subject/veztcxtx.html