zoukankan      html  css  js  c++  java
  • 经典排序算法

    经典排序算法 - 高速排序Quick sort

    原理,通过一趟扫描将要排序的数据切割成独立的两部分,当中一部分的全部数据都比另外一部分的全部数据都要小,然后再按此方法对这两部分数据分别进行高速排序,整个排序过程能够递归进行,以此达到整个数据变成有序序列

    举个样例

    如无序数组[6 2 4 1 5 9]

    a),先把第一项[6]取出来,

    用[6]依次与其余项进行比較,

    假设比[6]小就放[6]前边,2 4 1 5都比[6]小,所以所有放到[6]前边

    假设比[6]大就放[6]后边,9比[6]大,放到[6]后边,//6出列后大喝一声,比我小的站前边,比我大的站后边,行动吧!霸气十足~

    一趟排完后变成下边这样:

    排序前 6 2 4 1 5 9

    排序后 2 4 1 5 6 9


    b),对前半拉[2 4 1 5]继续进行高速排序

    反复步骤a)后变成下边这样:

    排序前 2 4 1 5

    排序后 1 2 4 5

    前半拉排序完毕,总的排序也完毕:

    排序前:[6 2 4 1 5 9]

    排序后:[1 2 4 5 6 9]

    排序结束

    下面代码实现仅供參考

    复制代码
            static int partition(int[] unsorted, int low, int high)
            {
                int pivot = unsorted[low];
                while (low < high)
                {
                    while (low < high && unsorted[high] > pivot) high--;
                    unsorted[low] = unsorted[high];
                    while (low < high && unsorted[low] <= pivot) low++;
                    unsorted[high] = unsorted[low];
                }
                unsorted[low] = pivot;
                return low;
            }
    
            static void quick_sort(int[] unsorted, int low, int high)
            {
                int loc = 0;
                if (low < high)
                {
                    loc = partition(unsorted, low, high);
                    quick_sort(unsorted, low, loc - 1);
                    quick_sort(unsorted, loc + 1, high);
                }
            }
    
            static void Main(string[] args)
            {
                int[] x = { 6, 2, 4, 1, 5, 9 };
                quick_sort(x, 0, x.Length - 1);
                foreach (var item in x)
                {
                    Console.WriteLine(item + ",");
                }
                Console.ReadLine();
            }
    复制代码
  • 相关阅读:
    Ansible Playbook 变量与 register 详解
    Ansible Playbook 初识
    Ansible Ad-Hoc与常用模块
    Ansible-免密登录与主机清单Inventory
    Ansible-安装配置
    Ansible-基本概述
    Linux tcpdump 命令详解与示例
    Linux 查看磁盘IO并找出占用IO读写很高的进程
    腾讯云部署Django成功,本地无法访问网页的解决办法
    CVM配置微信服务器之坑-待更新
  • 原文地址:https://www.cnblogs.com/zfyouxi/p/4292892.html
Copyright © 2011-2022 走看看