Skip to content

Latest commit

 

History

History
100 lines (78 loc) · 2.16 KB

README.md

File metadata and controls

100 lines (78 loc) · 2.16 KB

Majority Element

Given an array of size n, find the majority element. The majority element is the element that appears more than ⌊ n/2 ⌋ times.

You may assume that the array is non-empty and the majority element always exist in the array.

Example 1:

Input: [3,2,3]
Output: 3

Example 2:

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

Implementation 1 :

public int majorityElement(int[] nums) {
        if(nums == null || nums.length == 0)
            return -1;
        
        Map<Integer,Integer> map = new HashMap<>();
        for(int i : nums){
            if(map.containsKey(i)){
                map.put(i, map.get(i) + 1);
            } else{
                map.put(i, 1); 
            }
        }
        
        int majority = (int) Math.floor(nums.length / 2);
        for(Integer n : map.keySet()){
            if(map.get(n) > majority){
                return n;
            }
        }
        return -1;
}

Above implementation have runtime complexity of O(n) and space complexity of O(d), where d is the count of distinct numbers in the input array.

Runtime Complexity = O(n)
Space Complexity   = O(d)

Implementation 2 :

public int majorityElement(int[] nums) {
       if(nums == null || nums.length == 0)
            return -1;
            
       Arrays.sort(nums);
       return nums[nums.length / 2]; 
}

Above implementation have runtime complexity of O(nlogn) and space complexity of O(1)

Runtime Complexity = O(nlogn)
Space Complexity   = O(1)

Implementation 3 :

public int majorityElement(int[] nums) {
       if(nums == null || nums.length == 0)
            return -1;
        
       int result = 0, count = 0;
       for(int i = 0; i < nums.length; i++ ) {
          if(count == 0){
             result = nums[ i ];
             count = 1;
         } else if(result == nums[i]){
           count++;
         } else {
           count--;
         }
       }
 
     return result;
}

Above implementation have runtime complexity of O(n) and space complexity of O(1).

Runtime Complexity = O(n)
Space Complexity   = O(1)

References :

https://www.programcreek.com/2014/02/leetcode-majority-element-java/