欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Flutter Dart快速排序算法示例詳解

 更新時間:2022年12月09日 10:59:24   作者:Asscre  
這篇文章主要為大家介紹了Flutter Dart快速排序算法示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪

引言

在日常研發(fā)的過程中,我們無時無刻都在考慮自己開發(fā)的程序是否高效,一段好的程序執(zhí)行離不開對算法的深刻認識和熟練掌握。接下來的日子,我將帶著大家一起重溫一下常見的幾種算法。

先上大圖: 

下面我們一起來學習一下 快速排序算法 吧!

快速排序算法

維基百科介紹: 快速排序使用分治法(Divide and conquer)策略來把一個序列(list)分為較小和較大的2個子序列,然后遞歸地排序兩個子序列,最終合并得到一個從小到大的序列。

有聰明的小伙伴就會問了:什么是分治法策略呢?

分治法(Divide and conquer)

字面上的解釋是“分而治之”,就是把一個復雜的問題分成兩個或更多的相同或相似的子問題,再把子問題分成更小的子問題……直到最后子問題可以簡單的直接求解,原問題的解即子問題的解的合并。

由此就可以引出我們今天講的快速排序算法的實現步驟了:

  • 從數據中隨機獲取一個值,按這個值的大小對比分成左右兩個數據集合,左邊數據集合的值小于此值,右邊反之
  • 將兩邊數據進行遞歸調用步驟1
  • 將所有數據合并

快速排序算法實現

void main() {
  List<int> quickSort(List<int> arr) {
    // 處理邊界問題 
    if (arr.length <= 1) {
      return arr;
    }
    // 取出第一個值作為參考
    int splitData = arr[0];
    // 小于參考值的集合
    List<int> low = [];
    // 大于參考值的集合
    List<int> hight = [];
    // 與參考相等的集合
    List<int> mid = [];
    // 初次把參考值添加到mid中
    mid.add(splitData);
    for (int i = 1; i < arr.length; i++) {
      if (arr[i] < splitData) {
        // 小于
        low.add(arr[i]);
      } else if (arr[i] > splitData) {
        // 大于
        hight.add(arr[i]);
      } else {
        // 等于
        mid.add(arr[i]);
      }
    }
    // 二分數據后,再繼續(xù)遞歸整理
    low = quickSort(low);
    hight = quickSort(hight);
    // 最后合并
    return [...low, ...mid, ...hight];
  }
  const List<int> ary = [4, 5, 1, 3, 6, 2, 5, 6, 7, 2, 4];
  print(quickSort(ary));
}

至此,我們就重新溫習了一下 快排算法 !

更多關于Flutter Dart快速排序算法的資料請關注腳本之家其它相關文章!

相關文章

  • Flutter學習筆記(一)配置環(huán)境

    Flutter學習筆記(一)配置環(huán)境

    這篇文章主要介紹了Flutter學習筆記(一)配置環(huán)境,Flutter?app使用了?Dart語言,源自于?Google,現在是?ECMA?的標準,需要的朋友可以參考下
    2023-04-04
  • Flutter 語法進階抽象類和接口本質區(qū)別詳解

    Flutter 語法進階抽象類和接口本質區(qū)別詳解

    這篇文章主要為大家介紹了Flutter 語法進階抽象類和接口本質區(qū)別詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-08-08
  • Flutter入門學習Dart語言變量及基本使用概念

    Flutter入門學習Dart語言變量及基本使用概念

    這篇文章主要為大家介紹了Flutter入門學習Dart語言變量及基本使用概念,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-09-09
  • 一文詳解Dart如何實現多任務并行

    一文詳解Dart如何實現多任務并行

    這篇文章主要為大家介紹了Dart如何實現多任務并行示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-03-03
  • Flutter?圖片開發(fā)核心技能快速掌握教程

    Flutter?圖片開發(fā)核心技能快速掌握教程

    這篇文章主要為大家介紹了Flutter?圖片開發(fā)核心技能快速掌握教程,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-02-02
  • Dart多個future隊列完成加入順序關系及原子性論證

    Dart多個future隊列完成加入順序關系及原子性論證

    這篇文章主要介紹了Dart多個future隊列完成加入順序關系及原子性論證,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-11-11
  • 關于Dart中的異步編程

    關于Dart中的異步編程

    這篇文章主要介紹了關于Dart中的異步編程,dart 是強類型語言,但由于具備類型推導功能所以類型聲明是可選的,需要的朋友可以參考下
    2023-04-04
  • Android開發(fā)中Dart語言7個很酷的特點

    Android開發(fā)中Dart語言7個很酷的特點

    這篇文章主要為大家介紹了Android開發(fā)中Dart語言7個很酷的特點分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-05-05
  • Dart多態(tài)控制反轉編碼規(guī)范實例詳解

    Dart多態(tài)控制反轉編碼規(guī)范實例詳解

    這篇文章主要為大家介紹了Dart多態(tài)控制反轉編碼規(guī)范實例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-11-11
  • Dart?String字符串的常用方法總結概述

    Dart?String字符串的常用方法總結概述

    這篇文章主要為大家介紹了Dart?String字符串的常用方法概述,總結整理了大概4000多字,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-04-04

最新評論