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. 37、linux下安装python3.6和django

    37.1.安装python: 1.python介绍: python是一种面向对象的,解释型的计算机语言,它的特点是语法简介,优雅,简单易学.1989年诞生,Guido(龟叔)开发. 编译型语言:代码在 ...

  2. 不止Docker:8款容器管理开源方案

    Docker诞生于2013年,并普及了容器的概念,以至于大多数人仍然将容器的概念等同于"Docker容器". 作为第一个吃螃蟹的人,Docker设置了新加入者必须遵守的标准.例如, ...

  3. HDU 4445 Crazy Tank 高中物理知识忘得差不多了

    题意不难理解,仔细看题吧,就不说题意了 #include <iostream> #include <cstdio> #include <cstring> #incl ...

  4. 12.10File类

    要点提示:File类包含了获得一个文件/目录的属性,以及对文件/目录进行改名和删除的方法. 在文件系统中,每个文件都存放在一个目录下.绝对文件名,是由文件名和它的完整路径以及驱动器字母组成.例如,c: ...

  5. 整理!企业选择好用的CRM系统的要点(上)

    随着市场经济的发展,对任何行业的企业来说,客户都是非常重要的一个部分.CRM系统帮助企业做到以客户为中心,它可以根据客户的具体要求进行跟进和反馈,在很大程度上提高公司的客户服务水平和客户满意度,进而提 ...

  6. [心得]docker学习笔记

    1. docker是什么??? (1) docker是一台类似虚拟机的功能, 内部由一个个镜像组成, 镜像里可以运行容器, 而这个容器可以是任何东西, 比如mysql, 比如tomcat等等, 它的目 ...

  7. 元素类型为 "configuration" 的内容必须匹配 "(properties?,settings?,typeAliases?,typeHandlers?

    报错主要部分如下: Error building SqlSession.### Cause: org.apache.ibatis.builder.BuilderException: Error cre ...

  8. 输出 time 命令的结果到文件中

    译至:http://unicus.jp/skmk/archives/338 由于输出 time 命令的结果到文件时使用的错误的方式,所以将其记录下来. 环境是bash. 目标 将运行的a.out程序的 ...

  9. NetCore微服务简单流程审批数据库设计及后台服务开发

    1.数据库设计 -- ---------------------------- -- Table structure for TBase_Flow -- ----------------------- ...

  10. Blazor 数据绑定开发指南

    翻译自 Waqas Anwar 2021年3月21日的文章 <A Developer's Guide to Blazor Data Binding> [1] 现如今,大多数 Web 应用程 ...