Java中等题-多数元素2(力扣)【摩尔投票升级版】

给定一个大小为 n 的整数数组,找出其中所有出现超过 ⌊ n/3 ⌋ 次的元素。

示例 1:

复制代码
输入:nums = [3,2,3]
输出:[3]

示例 2:

复制代码
输入:nums = [1]
输出:[1]

示例 3:

复制代码
输入:nums = [1,2]
输出:[1,2]

方法一:使用HashMap,key记录值,value记录出现次数

java 复制代码
class Solution {
    public List<Integer> majorityElement(int[] nums) {
        Map<Integer,Integer>map=new HashMap<>();
        for(int x:nums){
            map.put(x,map.getOrDefault(x,0)+1);
        }
        int n=nums.length;
        int t=n/3;
        List<Integer> list=new ArrayList<>();
        for (Map.Entry<Integer, Integer> entry : map.entrySet()) {
            if(entry.getValue()>t){
                list.add(entry.getKey());
            }
        }

        return list;
    }
}

方法二:使用摩尔投票:一个数组中出现次数要大于总数的三分之一,满足条件的最多也只有两个数

java 复制代码
class Solution {
    public List<Integer> majorityElement(int[] nums) {
      int a=nums[0];
      int a1=0;
      int b=nums[0];
      int b1=0;

      for(int x:nums){
          if(x==a){
              a1++;
          }else if(x!=a&&x!=b&&b1==0){
              b=x;
              b1++;
          }else if(x!=a&&x!=b&&a1==0){
              a=x;
              a1++;
          }else if(x!=a&&x!=b){
              a1--;
              b1--;
          }else if(x==b){
              b1++;
          }

      }
      List<Integer>list=new ArrayList<>();
      a1=0;
      b1=0;
      for(int x:nums){
          if(x==a) a1++;
          else if(x==b) b1++;
      }
      int t=nums.length/3;
      if(a1>t){
          list.add(a);
      }
      if(b1>t){
          list.add(b);
      }
      return list;
    }
}
相关推荐
真的很上进5 分钟前
如何借助 Babel+TS+ESLint 构建现代 JS 工程环境?
java·前端·javascript·css·react.js·vue·html
呆呆的猫14 分钟前
【LeetCode】227、基本计算器 II
算法·leetcode·职场和发展
Tisfy16 分钟前
LeetCode 1705.吃苹果的最大数目:贪心(优先队列) - 清晰题解
算法·leetcode·优先队列·贪心·
余额不足1213837 分钟前
C语言基础十六:枚举、c语言中文件的读写操作
linux·c语言·算法
众拾达人37 分钟前
Android自动化测试实战 Java篇 主流工具 框架 脚本
android·java·开发语言
皓木.39 分钟前
Mybatis-Plus
java·开发语言
不良人天码星40 分钟前
lombok插件不生效
java·开发语言·intellij-idea
守护者1701 小时前
JAVA学习-练习试用Java实现“使用Arrays.toString方法将数组转换为字符串并打印出来”
java·学习
源码哥_博纳软云1 小时前
JAVA同城服务场馆门店预约系统支持H5小程序APP源码
java·开发语言·微信小程序·小程序·微信公众平台
禾高网络1 小时前
租赁小程序成品|租赁系统搭建核心功能
java·人工智能·小程序