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;
    }
  • 相关阅读:
    004-基于统计的翻译系统
    003-LDA
    002-01朴素贝叶斯到语言模型
    001-NLP基础
    11-word2vec
    009-TensorFlow-GPU版本安装
    008-TensorFlow的模型保存于加载
    007-RNN和LSTM
    006-卷积神经网络
    《笨方法学python》随笔
  • 原文地址:https://www.cnblogs.com/masbay/p/14197374.html
Copyright © 2011-2022 走看看