給定一個長度為n的整數陣列nums,請找出其中的「主要元素」。
主要元素指的是在陣列中出現次數超過⌊n / 2⌋的元素,我們可以假設主要元素一定存在於這個陣列中。
是一種用於找出具有多數元素的算法,它在陣列中的應用情境以及使用限制如下
使用情境
使用限制
在網頁頁面開發中,這種主要元素的問題常常應用在以下情境:
這道題目中使用了摩爾投票算法,該算法可以高效地找出主要元素。這對於處理大型數據集中的主要元素問題非常有用,並且可以在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;
};