Leetcode-Solutions

My Leetcode Solutions.

View on GitHub

169. Majority Element

Topics: Array Hash Table Divide and Conquer Sorting Counting

Solution

使用 Moore’s Voting Algorithm (戰鬥法),可以達到空間複雜度只有 O(1)。 刪去數列中兩個不同的數字,不會影響該數列的 Majority element。

Example 1

Input: nums = [3,2,3]
Output: 3
num ans count note
3 3 1 數字相同 count + 1
2 2 1 數字不同 count - 1 = 0 -> 從 1 開始
3 3 1 數字不同 count - 1 = 0 -> 從 1 開始

Example 2

Input: nums = [2,2,1,1,1,2,2]
Output: 2

num ans count note
2 2 1 數字相同 count + 1
2 2 2 數字相同 count + 1
1 2 1 數字不同 count - 1
1 1 1 數字不同 count - 1 = 0 -> 從 1 開始
1 1 2 數字相同 count + 1
2 1 1 數字不同 count - 1
2 2 1 數字不同 count - 1 = 0 -> 從 1 開始

Implementation

class Solution {
    fun majorityElement(nums: IntArray): Int {
        var answer = nums[0]
        var count = 0
        
        nums.forEach {
            count += if (it == answer) 1 else -1

            if (count == 0) {
                answer = it
                count = 1
            }
        }

        return answer
    }
}