五月天青色头像情侣网名,国产亚洲av片在线观看18女人,黑人巨茎大战俄罗斯美女,扒下她的小内裤打屁股

歡迎光臨散文網(wǎng) 會員登陸 & 注冊

插入排序的實現(xiàn)原理是什么?怎樣實現(xiàn)插入排序

2023-04-06 17:29 作者:云和數(shù)據(jù)何老師  | 我要投稿

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

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

【例3-5】demo05.html

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

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


插入排序的實現(xiàn)原理是什么?怎樣實現(xiàn)插入排序的評論 (共 條)

分享到微博請遵守國家法律
改则县| 斗六市| 墨江| 黄山市| 鹰潭市| 许昌县| 闽侯县| 湘乡市| 庆云县| 闵行区| 石棉县| 马龙县| 拜城县| 桓仁| 西平县| 汝阳县| 延川县| 万安县| 武汉市| 宾川县| 乐平市| 吉木乃县| 昌黎县| 康保县| 广元市| 郓城县| 拜城县| 钟祥市| 株洲市| 阿尔山市| 大荔县| 沙湾县| 读书| 连山| 铁力市| 内江市| 松潘县| 贵德县| 长治市| 皋兰县| 且末县|