LeetCode刷题记录--面试题 17.10. 主要元素

面试题 17.10. 主要元素

如果数组中多一半的数都是同一个,则称之为主要元素。给定一个整数数组,找到它的主要元素。若没有,返回-1。

示例 1:

输入:[1,2,5,9,5,9,5,5,5]
输出:5

 

示例 2:

输入:[3,2]
输出:-1

 

示例 3:

输入:[2,2,1,1,1,2,2]
输出:2

 

说明:
你有办法在时间复杂度为 O(N),空间复杂度为 O(1) 内完成吗?

根据题目要求,使用摩尔投票法:

摩尔投票算法是基于这个事实:每次从序列里选择两个不相同的数字删除掉(或称为“抵消”),最后剩下一个数字或几个相同的数字,就是出现次数大于总数一半的那个

 

LeetCode刷题记录--面试题 17.10. 主要元素_第1张图片

int majorityElement(int* nums, int numsSize){
    int res = nums[0];
    int count = 1;
    int i;
    for (i = 1; i < numsSize; i++) {
        int temp = nums[i];
        if (count == 0) {
            res = temp;
            count = 1;
        } else {
            if (res == temp) {
                count++;
            } else {
                count--;
            }
        }
    }
    if (count == 0) {
        return -1;
    }
    return res;
}

 

 

 

你可能感兴趣的:(Leetcode记录)