LeetCode 169 多數元素

2021-10-17 03:24:31 字數 578 閱讀 7386

給定乙個大小為 n 的陣列,找到其中的多數元素。多數元素是指在陣列**現次數 大於 ⌊ n/2 ⌋ 的元素。

你可以假設陣列是非空的,並且給定的陣列總是存在多數元素。

示例 1:

輸入:[3,2,3]

輸出:3

示例 2:

輸入:[2,2,1,1,1,2,2]

輸出:2

遍歷一遍陣列,用兩個變數輔助記錄,乙個記錄多數元素的出現次數,乙個記錄多數元素的索引

因為多數元素出現次數大於陣列長度一半,所以我們可以假定第乙個元素是目標,然後出現次數設為1

後續遍歷時遇到相同元素計數加一,反之減一

當計數為零時將目標元素更換為當前遍歷到的元素,繼續往後遍歷陣列重複剛才的做法

這樣到最後輔助變數記錄的索引一定會指向多數,因為它出現次數比其他所有元素出現次數加起來都多

class

solution

if(nums[i]

== nums[index]

)else

}return nums[index];}

}

LeetCode 169 多數元素

給定乙個大小為 n 的陣列,找到其中的多數元素。多數元素是指在陣列 現次數大於 n 2 的元素。你可以假設陣列是非空的,並且給定的陣列總是存在多數元素。示例 1 輸入 3,2,3 輸出 3 示例 2 輸入 2,2,1,1,1,2,2 輸出 2 思路一 既然是多數且超過n 2,那麼排序之後,這些數中間...

LeetCode 169 多數元素

題目描述 給定乙個大小為 n 的陣列,找到其中的多數元素。多數元素是指在陣列 現次數大於 n 2 的元素。你可以假設陣列是非空的,並且給定的陣列總是存在多數元素。法 1 直接遍歷 時間複雜度 o n 2 空間複雜度 o 1 public intmajorityelement1 int nums if...

leetcode169 多數元素

用乙個變數和計數器輔助,變數存放當前元素的值a,計數器統計當前元素出現次數n 如果遇到的元素和a不一樣,則n減一,如果n為零,則把a替換成遇到的元素,b設為1 最後的a即為要求的多數元素 class solution count candidate num 1 1 return candidate ...