zoukankan      html  css  js  c++  java
  • 【手撕】快速排序

    #include<iostream>
    #include<vector>
    using namespace std;
    
    void quick_sort(vector<int>& data, int left, int right)
    {
        if (left >= right)
        {
            return;
        }
        // 否则就开始在原数组上选区基准值进行交换
        int key = data[right]; // 选区最后一个数
        int i = left - 1;
        for (int j = left; j < right; j++)
        {
            if (data[j] <= key)
            {
                i++;
                swap(data[i], data[j]);
            }
        }
        // 将基准值放到i+1的位置
        swap(data[i + 1], data[right]);
        // i+1就是分界点
        int index = i + 1;
        quick_sort(data, left, index - 1);
        quick_sort(data, index + 1, right);
    }
    
    int main()
    {
        vector<int> data; // 输入要排序的数列
        int n, d;
        cin >> n; // 输入数列大小
        while (n-- && cin >> d) // 循环输入
        {
            data.push_back(d);
        }
    
        int left = 0;
        int right = data.size() - 1;
        quick_sort(data, left, right);
    
        for (int i = 0; i <= right; i++)
        {
            cout << data[i] << ' ';
        }
        cout << endl;
        return 0;
    }
  • 相关阅读:
    JSP内置对象
    Java数据结构
    Java引用传递
    椭圆曲线算法的基本原理及实现
    常见的Java异常
    Java数据结构
    Java数据结构
    重拾JSP
    [洛谷P6185] [NOI online 提高]T1 序列
    [题解][BZOJ1299]巧克力棒
  • 原文地址:https://www.cnblogs.com/masbay/p/14197374.html
Copyright © 2011-2022 走看看