IT日常-演算法排序(插入排序)

更新於 2024/11/02閱讀時間約 2 分鐘

前言

另一種基本演算法為:插入排序

就像玩撲克牌時在整理牌面一樣,依序把每張牌插入對應的順序中,來完成整個牌面的大小排序


排序演算法-插入排序

邏輯說明:

與泡沫排序不同的是:

1.第二層迴圈是利用第一層給的索引,做遞減的方式來把小於第一層迴圈索引內的數列先做排序。

2.隨著第一層迴圈新增的索引變數,在第二層迴圈中把每個新的數字加進來後再插入已經排序好的位置中。

範例陣列為:524613

第一層迴圈:

從陣列的索引變數: x 為基準,用comparedBox 儲存陣列[x]代表的值後,開始用第二層迴圈的值做對比移動

第二層迴圈:

透過小於comparedBox 的每個數字比較後把較大的數字一直往右移,把comparedBox 插入適合的索引位置的實作過程,可看以下範例了解實際交換的過程(以C#為範例)

程式碼範例:

public List<int> Sort(List<int> list) 
{
for (var x = 1; x < list.Count ; x++)
{
var y = x;
var comparedBox = list[x];
while (y >= 1 && comparedBox < list[y-1])
{
list[y] = list[y-1];
y--;
}
list[y] = comparedBox;
}
return list;
}

結語

時間複雜度: O(n2)

空間複雜度: θ(1) (不需要額外的陣列去存資料)


參考資料

基礎演算法系列 — 你只會用 built-in function 來排序嗎

Algorithm 演算法排序筆記

avatar-img
9會員
24內容數
此篇教學 : 使用GitHub架設免費的部落格網站,搭上Hexo靜態模板,在主題頁面中尋找屬於自己的風格套版,輕鬆擁有自己的Blog外,加上留言板/SEO等設定在記錄生活同時也增進與讀者的互動頻率。
留言0
查看全部
avatar-img
發表第一個留言支持創作者!
DavidHi的沙龍 的其他內容
本文探討排序演算法中最基本的一種:泡沫排序。雖然在日常工作中我們多使用內建函數來進行排序,但瞭解其背後的邏輯和效能對於演算法學習至關重要。此文分步介紹了泡沫排序的實作過程,並分析其時間與空間複雜度,助於讀者更深入掌握基礎演算法。
這篇文章主要是介紹了SQL查詢效能調校的方法,針對索引最佳化做了整理和分享,並提供了一些注意事項和建議。
本篇文章講解了字符編碼的基礎知識,包括ASCII, Unicode 和 UTF-8的誕生背景、解決的問題以及轉換方式。瞭解這些知識有助於解決在讀檔案時用錯誤的編碼方式轉換就會出現亂碼等問題。文章內容涉及電腦技術中的字符編碼相關歷史緣由,可幫助讀者解決相關疑問。
本文介紹了在升級.NET專案時使用.NET Upgrade Assistant的方法,詳細說明瞭如何下載、安裝並使用此工具來實現跨版本升級,並提供了升版過程中的注意事項。
在專案中與廠商測試API回傳的json字串出現無法解析的狀況,記錄發現過程與解決的紀錄,提供程式面和檔案面的解決方法。
在API介接中使用x-www-form-urlencoded格式時,可能會遇到一些踩坑的情況,本文分享了作者在這方面遇到的問題和解決方法。
本文探討排序演算法中最基本的一種:泡沫排序。雖然在日常工作中我們多使用內建函數來進行排序,但瞭解其背後的邏輯和效能對於演算法學習至關重要。此文分步介紹了泡沫排序的實作過程,並分析其時間與空間複雜度,助於讀者更深入掌握基礎演算法。
這篇文章主要是介紹了SQL查詢效能調校的方法,針對索引最佳化做了整理和分享,並提供了一些注意事項和建議。
本篇文章講解了字符編碼的基礎知識,包括ASCII, Unicode 和 UTF-8的誕生背景、解決的問題以及轉換方式。瞭解這些知識有助於解決在讀檔案時用錯誤的編碼方式轉換就會出現亂碼等問題。文章內容涉及電腦技術中的字符編碼相關歷史緣由,可幫助讀者解決相關疑問。
本文介紹了在升級.NET專案時使用.NET Upgrade Assistant的方法,詳細說明瞭如何下載、安裝並使用此工具來實現跨版本升級,並提供了升版過程中的注意事項。
在專案中與廠商測試API回傳的json字串出現無法解析的狀況,記錄發現過程與解決的紀錄,提供程式面和檔案面的解決方法。
在API介接中使用x-www-form-urlencoded格式時,可能會遇到一些踩坑的情況,本文分享了作者在這方面遇到的問題和解決方法。
你可能也想看
Google News 追蹤
Thumbnail
*合作聲明與警語: 本文係由國泰世華銀行邀稿。 證券服務係由國泰世華銀行辦理共同行銷證券經紀開戶業務,定期定額(股)服務由國泰綜合證券提供。   剛出社會的時候,很常在各種 Podcast 或 YouTube 甚至是在朋友間聊天,都會聽到各種市場動態、理財話題,像是:聯準會降息或是近期哪些科
Thumbnail
十三支在近年來有越來越多年輕人接觸到,大多數都是因為線上十三支 贏家娛樂城就要來跟大家分享關於十三支玩法怎麼玩 這裡有非常詳細的十三支教學,另外還有提供一些十三支技巧給大家參考 現在撲克牌遊戲非常多也非常流行,想了解更多這邊通通都有提供給大家
Thumbnail
本篇介紹單人遊戲的核心架構與邏輯,涵蓋發牌、抽牌、出牌及遊戲結算等重要步驟。文章也詳細介紹了使用 socket.io 建立連線的過程,並說明如何利用 React Hooks 管理遊戲狀態,提及後端伺服器如何處理玩家加入房間的事件,並簡要介紹了房間資訊的管理,此文將分為多篇進一步介紹遊戲事件部分。
Thumbnail
原版的官方規則導入記分機制,但因為計算過於繁複,所以一般遊玩時較少採用。本變體規則旨在還原原規則的策略性,並保留平常的遊玩樂趣。 1. 配件準備 4枚不同顏色的棋子(紅、藍、黃、綠),以及一張標記0~15的場地。 2. 記分方式 一開始所有棋子都在0的位置。每一局結束時,贏家以外的所有人拿出
Thumbnail
1.不要讓棋譜或棋書擋到棋盤,視野可以看到完整的棋盤。 2.可以將佈局階段角落的變化背起來,之後進階背30手、50手,訓練記憶力。 3.有時可以猜猜看高手會下在哪個範圍,準確度慢慢提高,大局觀也會慢慢養成哦!
Thumbnail
演算法就像盲盒,在你滑下一篇前,你永遠不會知道下一篇內容是甚麼。可好處是,這個盲盒是免費的、是廉價的,你可以用大量的時間去「刷」,你可以盡量刷,直到刷到自己喜歡的內容。有時候被低劣的內容吸引也沒關係,畢竟是免費的。可有時會刷到精緻、感興趣的內容,那就太幸運了,把他存起來,然後繼續刷。
學習如何提升子效,不浪費每一手棋的價值,透過精妙的佈局,不僅拓展你的棋界視野,更能在對局中一展長才⚫️⚪️
Thumbnail
*合作聲明與警語: 本文係由國泰世華銀行邀稿。 證券服務係由國泰世華銀行辦理共同行銷證券經紀開戶業務,定期定額(股)服務由國泰綜合證券提供。   剛出社會的時候,很常在各種 Podcast 或 YouTube 甚至是在朋友間聊天,都會聽到各種市場動態、理財話題,像是:聯準會降息或是近期哪些科
Thumbnail
十三支在近年來有越來越多年輕人接觸到,大多數都是因為線上十三支 贏家娛樂城就要來跟大家分享關於十三支玩法怎麼玩 這裡有非常詳細的十三支教學,另外還有提供一些十三支技巧給大家參考 現在撲克牌遊戲非常多也非常流行,想了解更多這邊通通都有提供給大家
Thumbnail
本篇介紹單人遊戲的核心架構與邏輯,涵蓋發牌、抽牌、出牌及遊戲結算等重要步驟。文章也詳細介紹了使用 socket.io 建立連線的過程,並說明如何利用 React Hooks 管理遊戲狀態,提及後端伺服器如何處理玩家加入房間的事件,並簡要介紹了房間資訊的管理,此文將分為多篇進一步介紹遊戲事件部分。
Thumbnail
原版的官方規則導入記分機制,但因為計算過於繁複,所以一般遊玩時較少採用。本變體規則旨在還原原規則的策略性,並保留平常的遊玩樂趣。 1. 配件準備 4枚不同顏色的棋子(紅、藍、黃、綠),以及一張標記0~15的場地。 2. 記分方式 一開始所有棋子都在0的位置。每一局結束時,贏家以外的所有人拿出
Thumbnail
1.不要讓棋譜或棋書擋到棋盤,視野可以看到完整的棋盤。 2.可以將佈局階段角落的變化背起來,之後進階背30手、50手,訓練記憶力。 3.有時可以猜猜看高手會下在哪個範圍,準確度慢慢提高,大局觀也會慢慢養成哦!
Thumbnail
演算法就像盲盒,在你滑下一篇前,你永遠不會知道下一篇內容是甚麼。可好處是,這個盲盒是免費的、是廉價的,你可以用大量的時間去「刷」,你可以盡量刷,直到刷到自己喜歡的內容。有時候被低劣的內容吸引也沒關係,畢竟是免費的。可有時會刷到精緻、感興趣的內容,那就太幸運了,把他存起來,然後繼續刷。
學習如何提升子效,不浪費每一手棋的價值,透過精妙的佈局,不僅拓展你的棋界視野,更能在對局中一展長才⚫️⚪️