首頁 web前端 js教程 JavaScript冒泡排序演算法

JavaScript冒泡排序演算法

Dec 19, 2016 pm 02:10 PM
冒泡排序

via冒泡排序由於比較簡單和容易理解,往往會成為人們首先想到的排序演算法。最基本的想法就是在一次裡面比較兩個數字,並確保他們在移動到其他項目之前有一個正確的順序。在每一關結束,有價值的「排序」到正確的位置,最終只留下其他項目排序。原文來自:http://caibaojian.com/javascript-bubble-sort.html

演算法實作想法

比較第一項和第二項

如果第一項應該在第二項的後面,交換他們

對比第二項和第三項

如果第二項應該在第三項之後,交換他們

持續直到數據結束

這個過程就是重複數次直到數據完全排序完畢,在每一次循環中,由於每一次的最後一項都是正確的排序,所以排序的項就越來越少。為了更好的理解,我們來進行一個陣列對比一下:[3, 2, 4, 5, 1].

例子對比過程

首先是正排序,對比第一項和第二項,由於2比3小,所以3排到後面,結果是[2,3,4,5,1].

第二項和第三項,順序是正確的,無須交換;第三項和第四項也是正確的,無須交換,第四項和第五項交換,結果為[2,3,4,1,5].

再次循環第一項和第二項,依次到第三項和第四項交換,為[2,3,1,4,5]

第三次循環,第二和第三交換為[2,1,3,4,5]

第四次循環,第一和第二交換要為[1,2,3,4,5]

實現冒泡排序的第一步就是創建一個方法來交換數組裡面的兩項,這個方法在很多低效率的排序中是比較常見的。一個簡單的javascript實作程式碼為:

function swap(items, firstIndex, secondIndex){
    var temp = items[firstIndex];
    items[firstIndex] = items[secondIndex];
    items[secondIndex] = temp;
}
登入後複製

via如上所述,這個排序演算法因為需要多次的排序,效率是比較低的。假設一個陣列有n個項,那麼則需要2的n次方來計算,讓我們來看看這個原文來自:http://caibaojian.com/javascript-bubble-sort.html

正向冒泡演算法

function bubbleSort(items){

    var len = items.length,
        i, j, stop;

    for (i=0; i < len; i++){
        for (j=0, stop=len-i; j < stop; j++){
            if (items[j] > items[j+1]){
                swap(items, j, j+1);
            }
        }
    }

    return items;
}
登入後複製

via外面的循環是控制了循環週期數,裡面的循環則是項與項之間的排序比較。

反向冒泡排序

function bubbleSort(items){
    var len = items.length,
        i, j;

    for (i=len-1; i >= 0; i--){
        for (j=len-i; j >= 0; j--){
            if (items[j] < items[j-1]){
                swap(items, j, j-1);
            }
        }
    }

    return items;
}
登入後複製

via上面兩個程式碼的結果是一樣的,都是從小到大排序,只是循環的順序略有不同,都是正序冒泡。

反序冒泡排序

其實就是判斷大小改變,第一項小於第二項時,交換位置,依次類推。

function bubbleSort2(items){
var len = items.length,
i,j,stop;
for(i=0;i<len; i++){
for(j=0,stop=len-i;j<stop;j++){
if(items[j]<items[j+1]){
swap(items,j,j+1);
}
}
}
return items;
}
登入後複製

總結

via再次說明一下,冒泡排序可能並不適用於你的實際工作中哦,它只是一個簡單的工具幫助我們了解算法並且為進一步獲取更多的知識打下基礎。而我們用得最多的可能是內建的Array.prototype.sort() 原型方法,這是由於它具有更高效率。



更多JavaScript冒泡排序演算法相關文章請關注PHP中文網!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

<🎜>:泡泡膠模擬器無窮大 - 如何獲取和使用皇家鑰匙
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
北端:融合系統,解釋
3 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

熱門話題

Java教學
1664
14
CakePHP 教程
1423
52
Laravel 教程
1321
25
PHP教程
1269
29
C# 教程
1249
24
Java資料結構與演算法:深入詳解 Java資料結構與演算法:深入詳解 May 08, 2024 pm 10:12 PM

資料結構與演算法是Java開發的基礎,本文深入探討Java中的關鍵資料結構(如陣列、鍊錶、樹等)和演算法(如排序、搜尋、圖演算法等)。這些結構透過實戰案例進行說明,包括使用陣列儲存分數、使用鍊錶管理購物清單、使用堆疊實現遞歸、使用佇列同步執行緒以及使用樹和雜湊表進行快速搜尋和身份驗證等。理解這些概念可以編寫高效且可維護的Java程式碼。

用 C++ 函數指標改造程式碼:提升效率和可重複使用性 用 C++ 函數指標改造程式碼:提升效率和可重複使用性 Apr 29, 2024 pm 06:45 PM

函數指標技術可提升程式碼效率和可重複使用性,具體表現為:提升效率:使用函數指標可減少重複程式碼,優化呼叫過程。提高可重複使用性:函數指標允許使用通用函數處理不同數據,提高程式的可重複使用性。

PHP 數組自訂排序演算法的編寫指南 PHP 數組自訂排序演算法的編寫指南 Apr 27, 2024 pm 06:12 PM

如何寫自訂PHP數組排序演算法?冒泡排序:透過比較和交換相鄰元素來排序數組。選擇排序:每次選擇最小或最大元素並與目前位置交換。插入排序:逐一插入元素到有序部分。

如何實作C#中的冒泡排序演算法 如何實作C#中的冒泡排序演算法 Sep 19, 2023 am 11:10 AM

如何實作C#中的冒泡排序演算法冒泡排序是一種簡單但有效的排序演算法,它透過多次比較相鄰的元素並交換位置來排列一個陣列。在本文中,我們將介紹如何使用C#語言實作冒泡排序演算法,並提供具體的程式碼範例。首先,讓我們來了解冒泡排序的基本原理。演算法從數組的第一個元素開始,與下一個元素進行比較。如果當前元素比下一個元素大,則交換它們的位置;如果當前元素比下一個元素小,則保持

分析 Go 語言中的時間複雜度與空間複雜度 分析 Go 語言中的時間複雜度與空間複雜度 Mar 27, 2024 am 09:24 AM

Go語言是一種越來越流行的程式語言,它被設計成易於編寫、易於閱讀和易於維護的語言,同時也支援高階程式設計概念。時間複雜度和空間複雜度是演算法和資料結構分析中重要的概念,它們衡量一個程式的執行效率和占用記憶體大小。在本文中,我們將重點分析Go語言中的時間複雜度和空間複雜度。時間複雜度時間複雜度是指演算法執行時間與問題規模之間的關係。通常用大O表示法來表示時間

各種 PHP 數組排序演算法的複雜度分析 各種 PHP 數組排序演算法的複雜度分析 Apr 27, 2024 am 09:03 AM

PHP陣列排序演算法複雜度:冒泡排序:O(n^2)快速排序:O(nlogn)(平均)歸併排序:O(nlogn)

Java資料結構與演算法:雲端運算實戰指南 Java資料結構與演算法:雲端運算實戰指南 May 09, 2024 am 08:12 AM

雲端運算中資料結構和演算法的使用至關重要,用於管理和處理大量資料。常見的資料結構包括數組、列表、哈希表、樹和圖。常用的演算法有排序演算法、搜尋演算法和圖演算法。利用Java的強大功能,開發者可以使用Java集合、執行緒安全資料結構和ApacheCommonsCollections來實作這些資料結構和演算法。

CS-第 3 週 CS-第 3 週 Apr 04, 2025 am 06:06 AM

算法是解決問題的指令集,其執行速度和內存佔用各不相同。編程中,許多算法都基於數據搜索和排序。本文將介紹幾種數據檢索和排序算法。線性搜索假設有一個數組[20,500,10,5,100,1,50],需要查找數字50。線性搜索算法會逐個檢查數組中的每個元素,直到找到目標值或遍歷完整個數組。算法流程圖如下:線性搜索的偽代碼如下:檢查每個元素:如果找到目標值:返回true返回falseC語言實現:#include#includeintmain(void){i

See all articles