[TS LeetCode] 169. Majority Element .Boyer-Moore 摩爾投票演算法

更新於 2024/10/15閱讀時間約 3 分鐘

題目摘要

給定一個長度為n的整數陣列nums,請找出其中的「主要元素」。

主要元素指的是在陣列中出現次數超過⌊n / 2⌋的元素,我們可以假設主要元素一定存在於這個陣列中。

題目知識點

  1. 主要元素:指的是在陣列中出現次數超過一半以上的元素。
  2. 摩爾投票算法:一種有效的解決主要元素問題的方法,能夠在O(n)時間內找到主要元素。

先備知識

  1. 了解陣列(Array)的基本概念和操作。
  2. 熟悉JavaScript/TypeScript中的迴圈和條件判斷。
  3. 理解如何使用變數來追蹤元素出現次數。

Boyer–Moore majority vote algorithm 多數投票演算法

是一種用於找出具有多數元素的算法,它在陣列中的應用情境以及使用限制如下

使用情境

  1. 主要元素檢測: 多數投票演算法主要用於找出陣列中出現次數超過一半的主要元素。這在選舉或投票系統中非常有用,用於確定最多選票的候選人。
  2. 數據流中的眾數:當你需要在數據流中即時找到最多出現的元素,摩爾投票算法可以動態處理數據並找出眾數。

使用限制

  1. 主要元素必須存在:摩爾投票演算法假設主要元素一定存在於陣列中。如果主要元素可能不存在,則需要額外的檢查。
  2. 不適用於多元素問題:這個算法僅適用於找出單一主要元素,當有多個主要元素時,它無法處理。
  3. 具體數量未知:這個算法不適用於在事先不知道主要元素應該出現多少次的情況。它僅告訴你主要元素是否存在並找到它。

應用情境

在網頁頁面開發中,這種主要元素的問題常常應用在以下情境:

  • 用戶投票:當需要確定在一次投票中哪個選項獲得了多數選票,可以使用主要元素算法。
  • 購物網站庫存:在網上購物平台上,需要找到最暢銷的產品,以便進一步推廣,這可以使用主要元素概念。
  • 活動參與者:在線上活動報名中,需要確定參與者中是否有某個主要參與者,以作出相關安排。

結論

這道題目中使用了摩爾投票算法,該算法可以高效地找出主要元素。這對於處理大型數據集中的主要元素問題非常有用,並且可以在O(n)時間內解決。摩爾投票算法的關鍵是使用兩個變數來追蹤候選元素和其出現次數,通過適當的條件判斷和更新,最終找到主要元素。這個方法在多個應用情境中都能派上用場,特別是當我們需要找到一組數據中的主要趨勢或最多的元素時。

解答:

Time Complexity : O(n)

n是陣列nums的長度

Space Complexity:O(1)

空間複雜度是指在執行程式期間所需的額外記憶體空間。這段程式碼中只使用了兩個變數,即"majority"和"count",它們的空間消耗是固定的,與輸入陣列的大小無關。因此,空間複雜度是O(1),稱為常數空間複雜度。

function majorityElement(nums: number[]): number {
    let majority: number = nums[0];
    let count: number = 0;

    for (let i = 0; i < nums.length; i++) {
        if (count === 0) {
            majority = nums[i];
        }

        majority === nums[i] ? count++ : count--
    }

    return majority;
};


相關連結




avatar-img
2會員
8內容數
"TypeScript LeetCode" 以 TypeScript 為工具,深入解析 LeetCode 上的算法和資料結構問題,提供清晰解釋和程式碼示範,幫助您精進 TypeScript 技能,解決挑戰性問題,無論您的程式開發水平如何。讓我們一同鑽研、提升,迎接算法挑戰,成長技術專長!,快速提高您的技能水平
留言0
查看全部
avatar-img
發表第一個留言支持創作者!
毛怪的沙龍 的其他內容
重要知識點: 1. TypeScript 全局擴展,使所有陣列都能使用 groupBy 方法。 2. 利用泛型創建彈性函數,提高代碼可重用性。 3. 迭代陣列中的元素,實現遍歷和處理功能。 4. 物件的鍵值對操作,用於建立以函數輸出為鍵的物件。
這篇文章介紹了如何建立一個時間限制的異步函數,以確保操作在指定時間內完成。 - 知識點包括異步編程、Promise使用、計時器函數和函數引數處理,以及錯誤處理。 - 應用情境包括網頁請求超時控制、前端性能優化和遊戲開發。 - 提高應用程式的可靠性和用戶體驗,確保操作不會花費過長的時間。 - 文章內
[Leetcode 筆記] TypeScript 2715. Timeout Cancellation 了解和有效使用 clearTimeout 和 setTimeout 可以提高JavaScript程序的效率和響應性。
分享今年29歲的我,離職之後開始探索自己的過程。
重要知識點: 1. TypeScript 全局擴展,使所有陣列都能使用 groupBy 方法。 2. 利用泛型創建彈性函數,提高代碼可重用性。 3. 迭代陣列中的元素,實現遍歷和處理功能。 4. 物件的鍵值對操作,用於建立以函數輸出為鍵的物件。
這篇文章介紹了如何建立一個時間限制的異步函數,以確保操作在指定時間內完成。 - 知識點包括異步編程、Promise使用、計時器函數和函數引數處理,以及錯誤處理。 - 應用情境包括網頁請求超時控制、前端性能優化和遊戲開發。 - 提高應用程式的可靠性和用戶體驗,確保操作不會花費過長的時間。 - 文章內
[Leetcode 筆記] TypeScript 2715. Timeout Cancellation 了解和有效使用 clearTimeout 和 setTimeout 可以提高JavaScript程序的效率和響應性。
分享今年29歲的我,離職之後開始探索自己的過程。
你可能也想看
Google News 追蹤
Thumbnail
*合作聲明與警語: 本文係由國泰世華銀行邀稿。 證券服務係由國泰世華銀行辦理共同行銷證券經紀開戶業務,定期定額(股)服務由國泰綜合證券提供。   剛出社會的時候,很常在各種 Podcast 或 YouTube 甚至是在朋友間聊天,都會聽到各種市場動態、理財話題,像是:聯準會降息或是近期哪些科
Thumbnail
TSM 即將於週四 (17日) 公布 3Q24 財報,在財報公布之前,我們上修 TSM 3Q24 營收預測至 234.7 億美元 (比先前 2Q24 財報公布之後的 3Q24 預期 229 億美元上修),但與 Bloomberg 共識的營收預期 234.5 億美元相比差距不大。
Thumbnail
題目摘要 給定一個整數陣列 `prices`,其中 `prices[i]` 代表第 `i` 天的股票價格。在每一天,你可以決定買入和/或賣出股票。然而,你同一時間只能擁有至多一股股票。你可以在同一天內買入然後立刻賣出股票。找出並返回你可以實現的最大利潤。
Thumbnail
題目摘要 給定一個陣列 prices,其中 prices[i] 代表第 i 天的股票價格。你希望透過在某一天購買一股股票,並在未來的某一天賣出它,以最大化你的利潤。如果無法獲得任何利潤,則返回 0。
Thumbnail
隨著科技的進步和遠程工作的興起,通訊方式正在經歷劇變。然而,這也讓許多人對於傳統的電話禮儀感到困惑。美國禮儀專家Lizzie Post針對這一問題,提出了六大電話禮儀建議,幫助我們在新的通訊環境下保持專業和禮貌。
Thumbnail
上週的雙11大家有買東西嗎? 去年雙11購入了tokuto的眼部按摩器TS-183使用滿一年心得分享給大家,希望能幫助跟我一樣眼睛容易酸澀又找不到相關心得文的人~
2021年底前價格應該會在 112-120之間移動
Thumbnail
電動汽車龍頭 Tesla,正式發布了他們在今年第二季的財報,交出了非常亮眼的成績,無論是在營收,或者是獲利上,都超過了市場上的分析師預期,也讓盤後特斯拉的股價上漲了 1%。當然,作為市場上最熱門的股票之一,特斯拉的營運狀況是非常多人關注的焦點,所以就讓科技巨頭解碼來帶大家看特斯拉最新一季的財報重點。
Thumbnail
*合作聲明與警語: 本文係由國泰世華銀行邀稿。 證券服務係由國泰世華銀行辦理共同行銷證券經紀開戶業務,定期定額(股)服務由國泰綜合證券提供。   剛出社會的時候,很常在各種 Podcast 或 YouTube 甚至是在朋友間聊天,都會聽到各種市場動態、理財話題,像是:聯準會降息或是近期哪些科
Thumbnail
TSM 即將於週四 (17日) 公布 3Q24 財報,在財報公布之前,我們上修 TSM 3Q24 營收預測至 234.7 億美元 (比先前 2Q24 財報公布之後的 3Q24 預期 229 億美元上修),但與 Bloomberg 共識的營收預期 234.5 億美元相比差距不大。
Thumbnail
題目摘要 給定一個整數陣列 `prices`,其中 `prices[i]` 代表第 `i` 天的股票價格。在每一天,你可以決定買入和/或賣出股票。然而,你同一時間只能擁有至多一股股票。你可以在同一天內買入然後立刻賣出股票。找出並返回你可以實現的最大利潤。
Thumbnail
題目摘要 給定一個陣列 prices,其中 prices[i] 代表第 i 天的股票價格。你希望透過在某一天購買一股股票,並在未來的某一天賣出它,以最大化你的利潤。如果無法獲得任何利潤,則返回 0。
Thumbnail
隨著科技的進步和遠程工作的興起,通訊方式正在經歷劇變。然而,這也讓許多人對於傳統的電話禮儀感到困惑。美國禮儀專家Lizzie Post針對這一問題,提出了六大電話禮儀建議,幫助我們在新的通訊環境下保持專業和禮貌。
Thumbnail
上週的雙11大家有買東西嗎? 去年雙11購入了tokuto的眼部按摩器TS-183使用滿一年心得分享給大家,希望能幫助跟我一樣眼睛容易酸澀又找不到相關心得文的人~
2021年底前價格應該會在 112-120之間移動
Thumbnail
電動汽車龍頭 Tesla,正式發布了他們在今年第二季的財報,交出了非常亮眼的成績,無論是在營收,或者是獲利上,都超過了市場上的分析師預期,也讓盤後特斯拉的股價上漲了 1%。當然,作為市場上最熱門的股票之一,特斯拉的營運狀況是非常多人關注的焦點,所以就讓科技巨頭解碼來帶大家看特斯拉最新一季的財報重點。