zoukankan      html  css  js  c++  java
  • 数据结构和算法基础之快速排序

    /// <summary>
            /// 快速排序
            /// 是对冒泡排序的一种改进,基本思想是选取一个记录作为枢轴,经过一趟排序,将整段序列分为两个部分,
            /// 其中一部分的值都小于枢轴,另一部分都大于枢轴。然后继续对这两部分继续进行排序,从而使整个序列达到有序。
            /// </summary>
            public static void QuiteSort(int[] arry,int begin,int end)
            {
                if (begin >= end) return;
                int pivotIndex = QuickSort_Once(arry, begin, end);
                QuiteSort(arry, begin, pivotIndex - 1);
                QuiteSort(arry, pivotIndex + 1, end);
            }
    
            private static int QuickSort_Once(int[] arry, int begin, int end)
            {
                int pivot = arry[begin];
                int i = begin;
                int j = end;
                while(i<j)
                {
                    //右到左寻找第一个小于基准pivot的元素
                    while(arry[j]>=pivot&&i<j)
                    {
                        j--;
                    }
                    arry[i] = arry[j];
                    //左到右寻找第一个大于基准pivot的元素
                    while (arry[i]<=pivot&&i<j)
                    {
                        i++;
                    }
                    arry[j] = arry[i];
                }
                //退出循环i=j
                arry[i] = pivot;
                return i;
            }
               
    
            private static void Swap(int[] arry, int i,int j)
            {
                int tmp = arry[i];
                arry[i] = arry[j];
                arry[j] = tmp;
            }

    时间复杂度:nlogn

  • 相关阅读:
    php 元字符与转义
    php内置函数
    php系统常量
    WPF 批量修改控件属性
    对实体属性值赋值(DATASET转list)
    WPF 进度条实现
    WPF 异步刷新主界面
    c# 依赖注入Export ImportMany
    Oracle 正则匹配实现字符拆分
    Oracle 获取表对应列信息和索引信息
  • 原文地址:https://www.cnblogs.com/weiqiangwaideshijie/p/10544833.html
Copyright © 2011-2022 走看看