力扣697(java)-数组的度(简单)
题目:
给定一个非空且只包含非负数的整数数组 nums,数组的 度 的定义是指数组里任一元素出现频数的最大值。
你的任务是在 nums 中找到与 nums 拥有相同大小的度的最短连续子数组,返回其长度。
示例 1:
输入:nums = [1,2,2,3,1]
输出:2
解释:
输入数组的度是 2 ,因为元素 1 和 2 的出现频数最大,均为 2 。
连续子数组里面拥有相同度的有如下所示:
[1, 2, 2, 3, 1], [1, 2, 2, 3], [2, 2, 3, 1], [1, 2, 2], [2, 2, 3], [2, 2]
最短连续子数组 [2, 2] 的长度为 2 ,所以返回 2 。
示例 2:
输入:nums = [1,2,2,3,1,4,2]
输出:6
解释:
数组的度是 3 ,因为元素 2 重复出现 3 次。
所以 [2,2,3,1,4,2] 是最短子数组,因此返回 6 。
提示:
nums.length 在 1 到 50,000 范围内。
nums[i] 是一个在 0 到 49,999 范围内的整数。
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/degree-of-an-array
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
解题思路:
1.定义三个HashMap,分别用来存储元素的度、元素出现的起始位置以及元素出现的末位置到首位值的长度
2.循环遍历整个数组,找到元素出现的次数、起始位置以及长度
3.循环遍历第一个HashMap的value值,找到数组的最大度
4.循环遍历第一个HashMap的key,如果key 对应的value与数组的最大度相等,则通过比较得到最短连续子数组的长度,输出结果
代码:
1 class Solution {
2 public int findShortestSubArray(int[] nums) {
3 int n = nums.length;
4 //1.考虑特殊情况
5 if(n == 1){
6 return 1;
7 }
8 //2.定义三个HashMap
9 Map<Integer, Integer> degree = new HashMap<>();
10 Map<Integer, Integer> first = new HashMap<>();
11 Map<Integer, Integer> last = new HashMap<>();
12 //3.循环数组,找到各元素出现的次数、起始位置和最后出现的长度
13 for(int i = 0; i < n; i++){
14 degree.put(nums[i], degree.getOrDefault(nums[i], 0) + 1);
15 if(!first.containsKey(nums[i])){
16 first.put(nums[i], i);
17 }
18 last.put(nums[i], i - first.get(nums[i]) + 1);
19 }
20 //4.找到数组的最大度
21 int maxcount = 0;
22 for(int m : degree.values()){
23 maxcount = Math.max(maxcount, m);
24 }
25 //5.找最短连续子数组
26 int minlength = Integer.MAX_VALUE;
27 for(int key : degree.keySet()){
28 //找到与数组相同的度
29 if(maxcount == degree.get(key)){
30 minlength = Math.min(minlength, last.get(key));
31 }
32 }
33 return minlength;
34
35 }
36 }

小知识:
HashMap的基础知识:
HashMap 是一个散列表,它存储的内容是键值对(key-value)映射
1.创建一个HashMap的对象degree,整型(Integer)的key和整型(Integer)的value:
HashMap<Integer, Integer> degree = new HashMap<Integer, Integer>();
2.添加键值对(key-value)可以使用 put() 方法:
degree.put(nums[i], "baidu")
3.使用 get(key) 方法来获取 key 对应的 value:
degree.get(nums[i])
4.使用 remove(key) 方法来删除 key 对应的键值对(key-value):
degree.remove(nums[i]);
5.删除所有键值对(key-value)可以使用 clear 方法:
degree.clear()
6.计算 HashMap 中的元素数量可以使用 size() 方法:
degree.size()
7.迭代HashMap,可以使用 for-each 来迭代 HashMap 中的元素,如果只想获取 key,可以使用 keySet() 方法,然后可以通过 get(key) 获取对应的 value,如果只想获取 value,可以使用 values() 方法。
for(int key : degree.keySet()){
//找到与数组相同的度
if(maxcount == degree.get(key)){
minlength = Math.min(minlength, last.get(key));
}
}
8.检查 hashMap 中是否存在指定的 key 对应的映射关系,使用containsKey(key) 方法
if(!first.containsKey(nums[i])){
first.put(nums[i], i);
}
9.获取指定 key 对应对 value,如果找不到 key ,则返回设置的默认值,使用getOrDefault() 方法
degree.getOrDefault( key,defaultValue)
力扣697(java)-数组的度(简单)的更多相关文章
- java数组复制的简单方法(一)
总结:主要是用a数组的长度等于b数组,然后a数组赋值给b数组,我不能想到这个办法,我还是不理解数组中length属性的含义 这里数组并没有正真复制过来,而是一个引用 package com.a; // ...
- java(数组及常用简单算法 )
数组 数组:数组是存储同一种数据类型数据的集合容器. 数组的定义格式: 数据类型[] 变量名 = new 数据类型[长度]; 数组的好处:对分配到数组对象中每一个数据都分配一个编号(索引值.角 ...
- 力扣561. 数组拆分 I-C语言实现-简单题
题目 传送门 给定长度为 2n 的整数数组 nums ,你的任务是将这些数分成 n 对, 例如 (a1, b1), (a2, b2), ..., (an, bn) ,使得从 1 到 n 的 min(a ...
- Java实现 LeetCode 697 数组的度(类似于数组的map)
697. 数组的度 给定一个非空且只包含非负数的整数数组 nums, 数组的度的定义是指数组里任一元素出现频数的最大值. 你的任务是找到与 nums 拥有相同大小的度的最短连续子数组,返回其长度. 示 ...
- 力扣485. 最大连续1的个数-C语言实现-简单题
题目 [题目传送门] 给定一个二进制数组, 计算其中最大连续1的个数. 示例 1: 输入: [1,1,0,1,1,1] 输出: 3 解释: 开头的两位和最后的三位都是连续1,所以最大连续1的个数是 3 ...
- 力扣566. 重塑矩阵-C语言实现-简单题
题目 传送门 在MATLAB中,有一个非常有用的函数 reshape,它可以将一个矩阵重塑为另一个大小不同的新矩阵,但保留其原始数据. 给出一个由二维数组表示的矩阵,以及两个正整数r和c,分别表示想要 ...
- 力扣832. 翻转图像-C语言实现-简单题
题目 传送门 文本 给定一个二进制矩阵 A,我们想先水平翻转图像,然后反转图像并返回结果. 水平翻转图片就是将图片的每一行都进行翻转,即逆序.例如,水平翻转 [1, 1, 0] 的结果是 [0, 1, ...
- 力扣算法经典第一题——两数之和(Java两种方式实现)
一.题目 难度:简单 给定一个整数数组 nums 和一个整数目标值 target,请你在该数组中找出 和为目标值 target 的那 两个 整数, 并返回它们的数组下标. 你可以假设每种输入只会对应一 ...
- java中把list列表转为arrayList以及arraylist数组截取的简单方法
java中把list列表转为arrayList以及arraylist数组截取的简单方法 package xiaobai; import java.util.ArrayList; import java ...
- [LeetCode] 697. Degree of an Array 数组的度
Given a non-empty array of non-negative integers nums, the degree of this array is defined as the ma ...
随机推荐
- day03-1-查看账单&结账功能
满汉楼03 4.功能实现05 4.8查看账单功能 按照之间搭建起来的框架,在BillService编写方法 4.8.1代码实现 1.修改Bill类 重写Bill类中的toString方法 @Overr ...
- 告别繁琐!1分钟带你构建RabbitMQ消息应用
支持.Net/.Net Core/.Net Framework,可以部署在Docker, Windows, Linux, Mac. RabbitMQ作为一款主流的消息队列工具早已广受欢迎.相比于其它的 ...
- Python 如何发送带Excel附件的邮件
import smtplib from email.mime.text import MIMEText from email.mime.multipart import MIMEMultipart f ...
- quartus之rom的IP测试
quartus之rom的IP测试 1.rom的作用 rom,就是只读存储器,内部数据在下载电路时就已经确认,不能使用信号驱动更改,只能够读取,一般用于比较重要的配置数据.在quartus中,可以直接调 ...
- SDC可伸缩的高维约束基准和算法
可伸缩的高维约束基准和算法 在过去二十年里,进化约束多目标优化受到了广泛的关注和研究,并且已经提出了一些基准测试约束多目标进化算法(CMOEAs).特别地,约束函数与目标函数值有紧密的联系,这使得 ...
- KingbaseES 逻辑读与物理读
oracle数据库中逻辑读,物理读 数据访问方式:数据库少不了和操作系统进行数据交互,表数据最好的方式是从数据库共享池中访问到,避免发生磁盘IO,当然如果共享池中没有访问到数据就难免发生磁盘IO. 物 ...
- archlinux调整分区及btrfs文件系统大小
1.防止数据丢失 有重要数据要先备份 最好现在虚拟机练习一下, 2.注意点 修改分区的初始位置似乎需要删除分区后重建分区,意味着分区数据全被删除. 所以修改分区初始位置可能需要其它办法 修改分区的初始 ...
- python 1992和2006年国家标准学科分类和代码标准化并存入MySQL数据库
数据表 代码 1 import pandas as pd 2 import pymysql 3 4 5 def get_subject_1992(): 6 res={} 7 the_former_co ...
- 初识Hbase架构以及数据读写(尚硅谷)
- ET介绍——Actor Location
Actor Location Actor模型只需要知道对方的InstanceId就能发送消息,十分方便,但是有时候我们可能无法知道对方的InstanceId,或者是一个Actor的InstanceId ...