Skip to content

Commit

Permalink
Update 剑指 offer 题解.md
Browse files Browse the repository at this point in the history
字母 中文间添加空格
  • Loading branch information
marshcat0 authored Jan 7, 2019
1 parent 4734da7 commit efebdb6
Showing 1 changed file with 1 addition and 1 deletion.
2 changes: 1 addition & 1 deletion docs/notes/剑指 offer 题解.md
Original file line number Diff line number Diff line change
Expand Up @@ -1853,7 +1853,7 @@ private void backtracking(char[] chars, boolean[] hasUsed, StringBuilder s) {

多数投票问题,可以利用 Boyer-Moore Majority Vote Algorithm 来解决这个问题,使得时间复杂度为 O(N)。

使用 cnt 来统计一个元素出现的次数,cnt初始为0。算法依次遍历数组中的数字,遍历到一个元素时,若cnt为0,则令统计元素为遍历到的该元素,并置cnt为1。若cnt不为0,且当遍历到的元素和统计元素相等时,令 cnt++,否则令 cnt--。如果前面查找了 i 个元素,且 cnt == 0,说明前 i 个元素没有 majority,或者有 majority,但是出现的次数少于 i / 2 ,因为如果多于 i / 2 的话 cnt 就一定不会为 0 。此时剩下的 n - i 个元素中,majority 的数目依然多于 (n - i) / 2,因此继续查找就能找出 majority。
使用 cnt 来统计一个元素出现的次数,cnt 初始为 0。算法依次遍历数组中的数字,遍历到一个元素时,若 cnt 为 0,则令统计元素为遍历到的该元素,并置 cnt 为 1。若 cnt 不为 0,且当遍历到的元素和统计元素相等时,令 cnt++,否则令 cnt--。如果前面查找了 i 个元素,且 cnt == 0,说明前 i 个元素没有 majority,或者有 majority,但是出现的次数少于 i / 2 ,因为如果多于 i / 2 的话 cnt 就一定不会为 0 。此时剩下的 n - i 个元素中,majority 的数目依然多于 (n - i) / 2,因此继续查找就能找出 majority。

```java
public int MoreThanHalfNum_Solution(int[] nums) {
Expand Down

0 comments on commit efebdb6

Please sign in to comment.