169. 多数元素

知识点:数组;排序;消消乐;分治

题目描述

给定一个大小为 n 的数组,找到其中的多数元素。多数元素是指在数组中出现次数 大于 ⌊ n/2 ⌋ 的元素。

你可以假设数组是非空的,并且给定的数组总是存在多数元素。

示例
输入:[3,2,3]
输出:3 输入:[2,2,1,1,1,2,2]
输出:2

解法一:排序

因为这道题中说了一定有一个数字是大于一半的,所以可以直接将数组进行排序,然后中间那个数一定是出现超过一半的。

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

解法二:消消乐(投票法)

一定有一个数字超过一半,所以如果两个不同的数字两两抵消的话最后留下来的那个一定就是出现次数超过一半的。先选最开始的作为候选人,然后count=1, 如果后面遇到一样的,count++,遇到不一样的,count--,count一旦到0以后,那就需要换新的候选人了。

class Solution {
public int majorityElement(int[] nums) {
int res = nums[0], count = 1;
for(int i = 1; i < nums.length; i++){
if(nums[i] != res){
count--;
if(count == 0){
res = nums[i];
count = 1;
}
}else{
count++;
}
}
return res;
}
}

解法三:分治

如果有一个数字出现次数超过了一半,那将这个数组分成两半后,那这个数必定至少在其中一部分超过一半。

反证:如果这个数字在两半里都没超过一半,那在整个数组里必定也没超过一半。所以可以分别求两个子数组里超过一半的数字,然后选出两个里真正的出现最多的。

  • 如果这两个数字相同,那必定就是它了;
  • 如果这两个数字不同,统计两个数字分别在数组里出现的次数,大的就是了;
class Solution {
public int majorityElement(int[] nums) {
return majorityElement(nums, 0, nums.length-1); //区间是左闭右闭;
}
private int majorityElement(int[] nums, int left, int right){
if(left == right){
return nums[left]; //结束条件;
}
int mid = left+((right-left) >> 1);
int leftnum = majorityElement(nums, left, mid); //左右两侧的超过一半的数字;
int rightnum = majorityElement(nums, mid+1, right); if(leftnum == rightnum) return leftnum;
int leftcount = countNum(nums, leftnum, left, right); //比较两个数字谁次数多;
int rightcount = countNum(nums, rightnum, left, right);
return leftcount > rightcount ? leftnum : rightnum;
}
private int countNum(int[] nums, int num, int left, int right){
int count = 0;
for(int i = left; i <= right; i++){
if(nums[i] == num){
count++;
}
}
return count;
}
}

【LeetCode】169. 多数元素的更多相关文章

  1. Java实现 LeetCode 169 多数元素

    169. 多数元素 给定一个大小为 n 的数组,找到其中的多数元素.多数元素是指在数组中出现次数大于 ⌊ n/2 ⌋ 的元素. 你可以假设数组是非空的,并且给定的数组总是存在多数元素. 示例 1: 输 ...

  2. LeetCode | 169. 多数元素

    给定一个大小为 n 的数组,找到其中的多数元素.多数元素是指在数组中出现次数大于 ⌊ n/2 ⌋ 的元素. 你可以假设数组是非空的,并且给定的数组总是存在多数元素. 示例 1: 输入: [3,2,3] ...

  3. Leetcode:169. 多数元素

    Leetcode:169. 多数元素 传送门 思路 一开始想到的一个很简单的做法就是hash法,直接利用打表记录次数再输出结果. 而利用BM算法可以令算法复杂度同样也在\(O(n)\)的情况下,将空间 ...

  4. LeetCode移除元素

    LeetCode 移除元素 题目描述 给你一个数组 nums 和一个值 val,你需要原地移除所有数值等于 val 的元素,并返回移除后数组的新长度. 不需要使用额外的数组空间,你必须仅使用 O(1) ...

  5. [LeetCode] 169. Majority Element 多数元素

    Given an array of size n, find the majority element. The majority element is the element that appear ...

  6. leetcode——169 Majority Element(数组中出现次数过半的元素)

    Given an array of size n, find the majority element. The majority element is the element that appear ...

  7. leetcode 169 Majority Element 冰山查询

    Given an array of size n, find the majority element. The majority element is the element that appear ...

  8. leetcode 169. Majority Element 、229. Majority Element II

    169. Majority Element 求超过数组个数一半的数 可以使用hash解决,时间复杂度为O(n),但空间复杂度也为O(n) class Solution { public: int ma ...

  9. Leetcode#169. Majority Element(求众数)

    题目描述 给定一个大小为 n 的数组,找到其中的众数.众数是指在数组中出现次数大于 ⌊ n/2 ⌋ 的元素. 你可以假设数组是非空的,并且给定的数组总是存在众数. 示例 1: 输入: [3,2,3] ...

随机推荐

  1. SpringBoot Validation优雅的全局参数校验

    前言 我们都知道在平时写controller时候,都需要对请求参数进行后端校验,一般我们可能会这样写 public String add(UserVO userVO) { if(userVO.getA ...

  2. Mac nasm 汇编入门

    下载 brew install nasm code SECTION .data msg: db "hello world", 0x0a len: equ $-msg SECTION ...

  3. hugegraph 源码解读 —— 索引与查询优化分析

    为什么要有索引 gremlin 其实是一个逐级过滤的运行机制,比如下面的一个简单的gremlin查询语句: g.V().hasLabel("label").has("pr ...

  4. Cent OS下安装JDK11

    自己云服务器以前装了个JDK1.7,最近发现出了jdk11,所以修改一下JDK版本: 我这里用的是Xshell和XFtp工具,下载地址:https://www.netsarang.com/downlo ...

  5. Shell常用工具find,grep,sed,awk,xargs命令

    最近学习shell命令,对grep,sed,awk命令有点混乱,故小结一下,巩固一遍. 注意:find , grep , sed, awk可使用基本正则表达式字符,find,grep,awk也支持扩展 ...

  6. idea本地调式tomcat源码

    前言 上篇文章中一直没搞定的tomcat源码调试终于搞明白了,p神的代码审计星球里竟然有,真的好b( ̄▽ ̄)d ,写一下过程,还有p神没提到的小坑 准备阶段 1.去官网下东西:https://tomc ...

  7. Python小白的数学建模课-B4. 新冠疫情 SIR模型

    Python小白的数学建模课-B4. 新冠疫情 SIR模型 传染病的数学模型是数学建模中的典型问题,常见的传染病模型有 SI.SIR.SIRS.SEIR 模型. SIR 模型将人群分为易感者(S类). ...

  8. 「CF997E」 Good Subsegments

    CF997E Good Subsegments 传送门 和 CF526F 差不多,只不过这道题是对多个子区间进行询问. 据说有一个叫析合树的东西可以在线做,不过有时间再说吧. 考虑离线询问,将每个询问 ...

  9. C++泛型编程-举例

    就是C++里面说的函数模板和类模板,我们以前写C语言的时候,不同的类型参数,可能要写不同的函数. C++的模板出现之后,就可以实现函数模板,函数模板可以接纳不同的类型,然后这些类型都可以调用同一个函数 ...

  10. Java基础00-Debug11

    1. Debug 1.1 Debug概述 1.2 Debug操作流程 1.2.1 如何加断点 1.2.2 如何运行加了断点的程序 1.2.3 看哪里 1.2.4 点哪里 1.2.5 如何删除断点 多个 ...