【Leetcode题单】(01 数组篇)刷题关键点总结01【数组的遍历】(4题)
- Easy数组的遍历
- 485. 最大连续 1 的个数 Easy
- 495. 提莫攻击 Easy
- 414. 第三大的数 Easy
- 628. 三个数的最大乘积 Easy
大家好,这里是新开的LeetCode刷题系列,以后尽量一天更新一个小章节。此系列应超过400题。
数组篇01《数组的遍历》,共4道题,均简单题。
注意看重点部分,总结起来是这一类题的规律。
Easy数组的遍历
485. 最大连续 1 的个数 Easy
485. 最大连续 1 的个数
public int findMaxConsecutiveOnes(int[] nums) {
int maxCount = 0, count = 0;
for (int num : nums) {
if (num == 1) {
count++;
} else {
maxCount = Math.max(maxCount, count);
count = 0;
}
}
maxCount = Math.max(maxCount, count);
return maxCount;
}
重点
- for循环遍历数组的格式
- Math.max() 的使用
- 采用 count 计数当前连续1数, maxCount 计数最大count
- 在代码尾部加一次判定
495. 提莫攻击 Easy
495. 提莫攻击
public int findPoisonedDuration(int[] timeSeries, int duration) {
int total = 0;
for(int i = 1; i < timeSeries.length; i++){
if (timeSeries[i] - timeSeries[i-1] < duration) {
total += timeSeries[i] - timeSeries[i-1];
} else {
total += duration;
}
}
total += duration;
return total;
}
重点
- timeSeries前后相减计算时长
- for循环的开始位是1
- 尾部增加duration
414. 第三大的数 Easy
414. 第三大的数
public int thirdMax(int[] nums) {
long a = Long.MIN_VALUE, b = Long.MIN_VALUE, c = Long.MIN_VALUE;
for (int num : nums) {
if (num > a) {
c = b;
b = a;
a = num;
} else if (num > b && num < a) {
c = b;
b = num;
} else if (num > c && num < b) {
c = num;
}
}
return c == Long.MIN_VALUE ? (int)a : (int)c;
}
重点
- Long.MIN_VALUE,这个取决于题目中的测试用例范围
- num > b && num < a 这个是因为b!= a,此处看清题目
- 结尾记得将数据类型转为int
628. 三个数的最大乘积 Easy
628. 三个数的最大乘积
public int maximumProduct(int[] nums) {
int max1 = Integer.MIN_VALUE, max2 = Integer.MIN_VALUE, max3 = Integer.MIN_VALUE;
int min1 = Integer.MAX_VALUE, min2 = Integer.MAX_VALUE;
for(int num : nums){
if(max1 < num){
max3 = max2;
max2 = max1;
max1 = num;
}else if(max2 < num){
max3 = max2;
max2 = num;
}else if(max3 < num){
max3 = num;
}
if(num < min1){
min2 = min1;
min1 = num;
}else if(num < min2){
min2 = num;
}
}
return Math.max(max1 * max2 * max3, min1 * min2 * max1);
}
重点
- 使用 minn 和 maxn 来指代第n大的数和第n小的数
- 数据的初始化
- 问题转化为求 三个最大数乘积 与 最大数与两个最小数乘积 的最大值
- 这种做法可以当做模版使用,找第n大的数。
这个系列希望能够帮助大家提高刷题效率,发现系列算法题目的常规思路,更快a题,速通Leetcode
b站【软件柠檬】以后会不定期分享计算机领域基础知识,求职干货,为大家助力实习和春秋招offer
公众号【软件柠檬】也会不定期更新优质内容,分享优质干货资料,希望能够帮助到大家~
❤️这里是 软件柠檬, 让我们一起学习进步~❤️