LeetCode - Easy - 169. Majority Element

桃扇骨 2022-12-29 09:53 214阅读 0赞

Topic

  • Array
  • Divide and Conquer
  • Bit Manipulation

Description

https://leetcode.com/problems/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:

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

Example 2:

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

Analysis

方法一:使用排序

方法二:使用HashMap

方法三:Moore投票算法(我认为众多方法中最优的)

方法四:位操作

方法五:硬币正反算法(赌运气,挺有趣)

方法六:分治算法

Submission

  1. import java.util.Arrays;
  2. import java.util.HashMap;
  3. import java.util.Map;
  4. public class MajorityElement {
  5. // 方法一:使用排序
  6. public int majorityElement1(int[] nums) {
  7. Arrays.sort(nums);
  8. return nums[nums.length / 2];
  9. }
  10. // 方法二:使用Hashtable
  11. public int majorityElement2(int[] nums) {
  12. Map<Integer, Integer> myMap = new HashMap<Integer, Integer>();
  13. // Hashtable<Integer, Integer> myMap = new Hashtable<Integer, Integer>();
  14. int ret = 0;
  15. for (int num : nums) {
  16. if (!myMap.containsKey(num))
  17. myMap.put(num, 1);
  18. else
  19. myMap.put(num, myMap.get(num) + 1);
  20. if (myMap.get(num) > nums.length / 2) {
  21. ret = num;
  22. break;
  23. }
  24. }
  25. return ret;
  26. }
  27. // 方法三:Moore 投票算法
  28. public int majorityElement3(int[] nums) {
  29. int count = 0, ret = 0;
  30. for (int num : nums) {
  31. if (count == 0)
  32. ret = num;
  33. if (num != ret)
  34. count--;
  35. else
  36. count++;
  37. }
  38. return ret;
  39. }
  40. // 方法四:位操作1
  41. public int majorityElement4_1(int[] nums) {
  42. int[] bit = new int[32];
  43. for (int num : nums)
  44. for (int i = 0; i < 32; i++)
  45. if ((num >> (31 - i) & 1) == 1)
  46. bit[i]++;
  47. int ret = 0;
  48. for (int i = 0; i < 32; i++) {
  49. bit[i] = bit[i] > nums.length / 2 ? 1 : 0;
  50. ret += bit[i] * (1 << (31 - i));
  51. }
  52. return ret;
  53. }
  54. // 方法四:位操作2
  55. public int majorityElement4_2(int[] nums) {
  56. int majority = 0;
  57. for (int i = 0, mask = 1; i < 32; i++, mask <<= 1) {
  58. int bits = 0;
  59. for (int num : nums) {
  60. if ((num & mask) > 0) {
  61. bits++;
  62. }
  63. }
  64. if (bits > nums.length / 2) {
  65. majority |= mask;
  66. }
  67. }
  68. return majority;
  69. }
  70. // 方法五:概率计算
  71. public int majorityElement5(int[] nums) {
  72. int n = nums.length, candidate = 0;
  73. while (true) {
  74. candidate = nums[(int) (Math.random() * n)];
  75. int counter = 0;
  76. for (int num : nums) {
  77. if (num == candidate) {
  78. counter++;
  79. }
  80. }
  81. if (counter > n / 2) {
  82. break;
  83. }
  84. }
  85. return candidate;
  86. }
  87. // 方法六:分治算法
  88. public int majorityElement6(int[] nums) {
  89. return findMajority(nums, 0, nums.length - 1);
  90. }
  91. private int findMajority(int[] nums, int low, int high) {
  92. if (low == high)
  93. return nums[low];
  94. int mid = low + (high - low) / 2;
  95. int left = findMajority(nums, low, mid);
  96. int right = findMajority(nums, mid + 1, high);
  97. if (left == right)
  98. return left;
  99. int countLeft = getFreq(nums, left, low, mid);
  100. int countRight = getFreq(nums, right, mid + 1, high);
  101. if (countLeft > countRight)
  102. return left;
  103. return right;
  104. }
  105. private int getFreq(int[] nums, int val, int low, int high) {
  106. int res = 0;
  107. for (int i = low; i <= high; i++) {
  108. if (nums[i] == val)
  109. res++;
  110. }
  111. return res;
  112. }
  113. }

Test

  1. import static org.junit.Assert.*;
  2. import org.junit.Test;
  3. public class MajorityElementTest {
  4. @Test
  5. public void test() {
  6. MajorityElement obj = new MajorityElement();
  7. int[][] array = { { 1, 1, 1, 1, 1, 3, 4, 5},
  8. { 3, 2, 3}, { 2, 2, 1, 1, 1, 2, 2}};
  9. assertEquals(1, obj.majorityElement1(array[0]));
  10. assertEquals(3, obj.majorityElement1(array[1]));
  11. assertEquals(2, obj.majorityElement1(array[2]));
  12. assertEquals(1, obj.majorityElement2(array[0]));
  13. assertEquals(3, obj.majorityElement2(array[1]));
  14. assertEquals(2, obj.majorityElement2(array[2]));
  15. assertEquals(1, obj.majorityElement3(array[0]));
  16. assertEquals(3, obj.majorityElement3(array[1]));
  17. assertEquals(2, obj.majorityElement3(array[2]));
  18. assertEquals(1, obj.majorityElement4_1(array[0]));
  19. assertEquals(3, obj.majorityElement4_1(array[1]));
  20. assertEquals(2, obj.majorityElement4_1(array[2]));
  21. assertEquals(1, obj.majorityElement4_2(array[0]));
  22. assertEquals(3, obj.majorityElement4_2(array[1]));
  23. assertEquals(2, obj.majorityElement4_2(array[2]));
  24. assertEquals(1, obj.majorityElement5(array[0]));
  25. assertEquals(3, obj.majorityElement5(array[1]));
  26. assertEquals(2, obj.majorityElement5(array[2]));
  27. assertEquals(1, obj.majorityElement6(array[0]));
  28. assertEquals(3, obj.majorityElement6(array[1]));
  29. assertEquals(2, obj.majorityElement6(array[2]));
  30. }
  31. }

发表评论

表情:
评论列表 (有 0 条评论,214人围观)

还没有评论,来说两句吧...

相关阅读