zoukankan      html  css  js  c++  java
  • 对于快速排序的理解

    普通快速排序其实就是递归分割,首先去一个基准数将数组以此为大小分割成两份,然后再递归对此两份数组分别再进行同样的操作。


    int getIndex(int* pArry, int low, int high)
    {
    int temp = pArry[low];
    while (low < high)
    {
    while (low < high && pArry[high] >= temp)
    {
    high--;
    }
    pArry[low] = pArry[high];

    while (low < high && pArry[low] <= temp)
    {
    low++;
    }
    pArry[high] = pArry[low];

    if (high != low)
    {
    std::cout << "low : " << low << " " << "high: " << high << " " << "array : " << pArry[0] << " " << pArry[1] << " " << pArry[2] << " " << pArry[3] << " "
    << pArry[4] << " " << pArry[5] << " " << pArry[6] << " " << pArry[7] << " " << pArry[8] << " " << pArry[9] << endl;
    }
    }
    pArry[low] = temp;
    std::cout << "low : " << low << " " << "high: " << high << " " << "array : " << pArry[0] << " " << pArry[1] << " " << pArry[2] << " " << pArry[3] << " "
    << pArry[4] << " " << pArry[5] << " " << pArry[6] << " " << pArry[7] << " " << pArry[8] << " " << pArry[9] << endl;
    return low;
    }

    int quicksort_ordinary(int* pArry, int low, int high)
    {
    if (low < high)
    {
    int index = getIndex(pArry, low, high);
    quicksort_ordinary(pArry, low, index - 1);
    quicksort_ordinary(pArry, index + 1, high);
    }
    return 0;
    }

    int main(int argc, char* argv[])
    {

    srand(time(nullptr));
    int array[10] = { 0 }; // { 63, 85, 41, 74, 51, 30, 75, 4, 23 };
    for (int i = 0; i < 10; ++i)
    {
    array[i] = rand() % 100 + 1;
    }

    std::cout << "original array : " << array[0] << " " << array[1] << " " << array[2] << " " << array[3] << " "
    << array[4] << " " << array[5] << " " << array[6] << " " << array[7] << " " << array[8] << " " << array[9] << endl;

    quicksort_ordinary(array, 0, 9);


    char t = getchar();
    return 1;
    }

  • 相关阅读:
    GRIDVIEW导出到EXCEL
    数据表示:字节 高位低位
    js学习笔记0
    12奇招,循序删除顽固的文件
    加快开关机速度
    PHP正则表达式的快速学习
    firefox下height不能自动撑开的解决办法
    给MySQL加密(也适用于Wamp5中)
    我的电脑创建资源管理器
    css 圆角7种CSS圆角框解决方案
  • 原文地址:https://www.cnblogs.com/lingqingyu/p/12606409.html
Copyright © 2011-2022 走看看