米利唐_后腰_乌克兰足球超级联赛_中国竞彩欧赔 - 足球竞彩分析

集團官網
  • 國家級全民數字素養與技能培訓基地
  • 河南省第一批產教融合型企業建設培育單位
  • 鄭州市數字技能人才(碼農)培養評價聯盟

插入排序的實現原理是什么?怎樣實現插入排序

編輯:云和數據 日期:2023-04-06 17:03

插入排序是冒泡排序的優化,是一種直觀的簡單排序算法。它的實現原理是,通過構建有序數組元素的存儲,對于未排序的數組元素,在已排序的數組中從最后一個元素向第一個元素遍歷,找到相應位置并插入。其中,待排序數組的第1個元素會被看作是一個有序的數組,從第2個至最后一個元素會被看作是一個無序數組。如按照從小到大的順序完成插入排序,如圖3-10所示。

圖3-10插入排序從圖3-10可以看出,插入排序比較的次數與無序數組的長度相等,每次無序數組元素與有序數組中的所有元素進行比較,比較后找到對應位置插入,最后即可得到一個有序數組。了解插入排序實現的原理后,下面使用JavaScript實現插入排序。具體如例3-5所示。

【例3-5】demo05.html

????var?arr?=?[89,?56,?100,?21,?87,?45,?1,?888];?//?待排序數組console.log('待排序數組:'?+?arr);//?按照從小到大的順序排列5for?(vari?=?1;?i??0;?--j)?{?//?遍歷并比較一個無序數組元素與所有有序數組元素????if?(arr[j?-?1]?>?arr[j])?{????????[arr[j?-?1],?arr[j]]?=?[arr[j],?arr[j?-?1]];????}}}//?輸出從小到大排序后的數組console.log('排序后的數組:'?+?arr);?

在上述代碼中,我們假設待查找的數組arr的第1個元素是一個按從小到大排列的有序數組,arr剩余的元素為無序數組。然后通過第5~11行代碼完成插入排序。其中,第7~9行代碼用于無序數組元素與有序數組中的元素進行比較,若無序元素arr[j]小于有序數組中的元素,則進行插入。效果如圖3-11所示。

相關內容

搶先一步 鴻蒙(HarmonyOS)應用開發者高級認證 免費考! 適合人群計算機相關專業在校生(技師、中職、高職、本科、研究生)對鴻蒙(HarmonyOS)有興趣的非計算機相關專業在校生目前正在從事移動應用的開發者目前正在從事計算機行業相關的人計算機專業高校老師所有對鴻蒙(HarmonyOS)有興趣的人 培訓方案掌握鴻蒙的核心概念和端云一體化開發、... 什么是Java的多態性(polymorphism)?它有哪些不同的形式? 多態性是Java面向對象編程的一個重要概念,它允許不同的對象以一致的方式響應同一個方法調用,具體表現為對象在運行時可以表現出多個不同的形態。多態性主要有兩種不同的形式:編譯時多態性(靜態多態性)和運行時多態性(動態多態性)。1. 編譯時多態性(靜態多態性):   ... 如何學習和搭建Hadoop開發環境? Hadoop是大數據處理領域的重要平臺,能夠處理和分析大量數據。為了有效地利用Hadoop,我們需要學習其基礎知識,并正確搭建開發環境。下面是詳細的學習和搭建指南。一、學習Hadoop基礎掌握基礎概念和原理Hadoop主要由HDFS和MapReduce兩部分組成。HDFS是分布式文件系統,Ma... UI 設計學習如何進階成為高手 我總結了六種方法,幫助你走出舒適區,提高技能,成長為自信且經驗豐富的UI設計高手一位經驗豐富的 UI 設計師,往往十分看中應用程序界面的吸引力和視覺刺激,確保滿足用戶期望和需求。但是,如果你已經在 UI 設計圈摸爬滾打多年,仍然沒有出色的作品,那你極有可能是因為陷入了一個舒適圈,UI技能一直原... 在Java中Executor和Executors的區別? 在Java中,Executor和Executors都與線程池和并發執行有關,但它們是不同的概念和類。1.ExecutorExecutor是一個接口,位于java.util.concurrent包中,用于表示一個執行任務的執行器。它只定義了一個方法:void execute(Runnable c... String類型的常見命令有哪些? String類型,也就是字符串類型,是Redis中最簡單的存儲類型。其value是字符串,不過根據字符串的格式不同,又可以分為3類:string是普通字符串,int整數類型,可以做自增、自減操作,float浮點類型,可以做自增、自減操作。String的常見命令有:SET:添加或者修改已經存在的...