-
Notifications
You must be signed in to change notification settings - Fork 23
/
Copy pathMajority Number II.java
executable file
·89 lines (77 loc) · 2.39 KB
/
Majority Number II.java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
M
tags:Greedy, Enumeration
#### Array
- 分三份:a b c考虑
- 若a: countA++; 或b: countB++
- 或c:countA--, countB--
- 注意: 按照if statement的顺序, valA&&countA 比valB&&countB有优先性
- 最后出现的两个count>0的a和b,自然是potentially大于1/3的。其中有一个大于1/3.
- 比较countA和countB哪个大,就return哪一个。
```
/*
LintCode:
Given an array of integers, the majority number is the number that
occurs more than 1/3 of the size of the array.
Find it.
Example
Given [1, 2, 1, 2, 1, 3, 3], return 1.
Challenge
O(n) time and O(1) extra space.
*/
/*
Thinking process:
Need to think the relations of 3 parts of the array:
1. Consider a and b.
2. Consider the rest of the array is in set c, which can contain all different elements.
3. Two if statement makes sure a and b fall into 1/3 of the conditions.
Discuss relations between a, b, c
Implementation:
1. Have valA and valB two pointers to represent a and between
2. Check valA against the array to count duplicates, similar as in Majority Number I
3. Check valB against .....
4. Note: at each index i, only one of valA or valB is checked. That means, we evaluate a and b individually against the section c.
5. At the end, we found 2 candidates: a and b. Now compare the # of a and b to see which is greater.
*/
// Lintcode
public class Solution {
/*
* @param nums: a list of integers
* @return: The majority number that occurs more than 1/3
*/
public int majorityNumber(List<Integer> nums) {
if (nums == null || nums.size() == 0) {
return -1;
}
int valA = 0;
int valB = 0;
int countA = 0;
int countB = 0;
for (int num : nums) {
if (num == valA) {
countA++;
} else if (num == valB) {
countB++;
} else if (countA == 0) {
valA = num;
countA++;
} else if (countB == 0){
valB = num;
countB++;
} else {//None of a || b matches
countA--;
countB--;
}
}//For
countA = 0;
countB = 0;
for (int num : nums) {
if (num == valA) {
countA++;
} else if (num == valB) {
countB++;
}
}
return countA > countB ? valA : valB;
}
}
```