力扣爆刷第135天之数组五连刷(双指针快慢指针滑动窗口)

2024-05-10 07:28

本文主要是介绍力扣爆刷第135天之数组五连刷(双指针快慢指针滑动窗口),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

力扣爆刷第135天之数组五连刷(双指针快慢指针滑动窗口)

文章目录

      • 力扣爆刷第135天之数组五连刷(双指针快慢指针滑动窗口)
      • 一、704. 二分查找
      • 二、27. 移除元素
      • 三、977. 有序数组的平方
      • 四、209. 长度最小的子数组
      • 五、59. 螺旋矩阵 II

一、704. 二分查找

题目链接:https://leetcode.cn/problems/binary-search/description/
思路:经典二分查找算法,每次与中值比较,中值大于target右边界左移,中值小于target左边界右移。

class Solution {public int search(int[] nums, int target) {int left = 0, right = nums.length - 1;while(left <= right) {int mid = left + (right - left) / 2;if(nums[mid] == target) {return mid;}else if(nums[mid] > target) {right = mid - 1;}else{left = mid + 1;}}return -1;}
}

二、27. 移除元素

题目链接:https://leetcode.cn/problems/remove-element/description/
思路:移出相同元素,经典快慢指针,元素不等慢指针才走。

class Solution {public int removeElement(int[] nums, int val) {int slow = 0;for(int i = 0; i < nums.length; i++) {if(nums[i] != val) {nums[slow++] = nums[i];}}return slow;}}

三、977. 有序数组的平方

题目链接:https://leetcode.cn/problems/squares-of-a-sorted-array/description/
思路:画了一个非常清晰易懂的图,对含有负数的有序数组进行平方之后的排序,其实平方后就是第二个图形,只需要双指针从两端进行归并排序即可。
在这里插入图片描述

class Solution {public int[] sortedSquares(int[] nums) {int len = nums.length, left = 0, right = len-1;int[] result = new int[len];for(int i = 0; i < len; i++) {nums[i] *= nums[i]; }int k = right;while(left <= right) {if(nums[left] > nums[right]) {result[k--] = nums[left++];}else{result[k--] = nums[right--];}}return result;}
}

四、209. 长度最小的子数组

题目链接:https://leetcode.cn/problems/minimum-size-subarray-sum/description/
思路:求满足目标和的最短长度子数组,这种题目一看就是滑动窗口,使用快慢指针,快指针扩大窗口,慢指针缩小窗口。

class Solution {public int minSubArrayLen(int target, int[] nums) {int len = nums.length, min = len+1, sum = 0, slow = 0, fast = 0;while(fast < len) {sum += nums[fast++];while(sum >= target) {min = Math.min(min, fast - slow);sum -= nums[slow++];}}return min == len+1 ? 0 : min; }
}

五、59. 螺旋矩阵 II

题目链接:https://leetcode.cn/problems/spiral-matrix-ii/description/
思路:螺旋矩阵非常经典的题目,分别控制四个边界即可。

class Solution {public int[][] generateMatrix(int n) {int[][] nums = new int[n][n];int k = 1, sum = n * n;int left = 0, right = n, up = 0, down = n;while(k <= sum) {if(up < down) {for(int i = left; i < right; i++) {nums[up][i] = k++;}up++;}if(left < right) {for(int i = up; i < down; i++) {nums[i][right-1] = k++;}right--;}if(up < down) {for(int i = right-1; i >= left; i--) {nums[down-1][i] = k++;}down--;}if(left < right) {for(int i = down-1; i >= up; i--) {nums[i][left] = k++;}left++;}}return nums;}
}

这篇关于力扣爆刷第135天之数组五连刷(双指针快慢指针滑动窗口)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/975813

相关文章

hdu2241(二分+合并数组)

题意:判断是否存在a+b+c = x,a,b,c分别属于集合A,B,C 如果用暴力会超时,所以这里用到了数组合并,将b,c数组合并成d,d数组存的是b,c数组元素的和,然后对d数组进行二分就可以了 代码如下(附注释): #include<iostream>#include<algorithm>#include<cstring>#include<stack>#include<que

hdu 1166 敌兵布阵(树状数组 or 线段树)

题意是求一个线段的和,在线段上可以进行加减的修改。 树状数组的模板题。 代码: #include <stdio.h>#include <string.h>const int maxn = 50000 + 1;int c[maxn];int n;int lowbit(int x){return x & -x;}void add(int x, int num){while

【C++学习笔记 20】C++中的智能指针

智能指针的功能 在上一篇笔记提到了在栈和堆上创建变量的区别,使用new关键字创建变量时,需要搭配delete关键字销毁变量。而智能指针的作用就是调用new分配内存时,不必自己去调用delete,甚至不用调用new。 智能指针实际上就是对原始指针的包装。 unique_ptr 最简单的智能指针,是一种作用域指针,意思是当指针超出该作用域时,会自动调用delete。它名为unique的原因是这个

C语言:柔性数组

数组定义 柔性数组 err int arr[0] = {0}; // ERROR 柔性数组 // 常见struct Test{int len;char arr[1024];} // 柔性数组struct Test{int len;char arr[0];}struct Test *t;t = malloc(sizeof(Test) + 11);strcpy(t->arr,

C语言指针入门 《C语言非常道》

C语言指针入门 《C语言非常道》 作为一个程序员,我接触 C 语言有十年了。有的朋友让我推荐 C 语言的参考书,我不敢乱推荐,尤其是国内作者写的书,往往七拼八凑,漏洞百出。 但是,李忠老师的《C语言非常道》值得一读。对了,李老师有个官网,网址是: 李忠老师官网 最棒的是,有配套的教学视频,可以试看。 试看点这里 接下来言归正传,讲解指针。以下内容很多都参考了李忠老师的《C语言非

C 语言基础之数组

文章目录 什么是数组数组变量的声明多维数组 什么是数组 数组,顾名思义,就是一组数。 假如班上有 30 个同学,让你编程统计每个人的分数,求最高分、最低分、平均分等。如果不知道数组,你只能这样写代码: int ZhangSan_score = 95;int LiSi_score = 90;......int LiuDong_score = 100;int Zhou

使用JS/Jquery获得父窗口的几个方法(笔记)

<pre name="code" class="javascript">取父窗口的元素方法:$(selector, window.parent.document);那么你取父窗口的父窗口的元素就可以用:$(selector, window.parent.parent.document);如题: $(selector, window.top.document);//获得顶级窗口里面的元素 $(

两数之和--力扣1

两数之和 题目思路C++代码 题目 思路 根据题目要求,元素不能重复且不需要排序,我们这里使用哈希表unordered_map。注意题目说了只对应一种答案。 所以我们在循环中,使用目标值减去当前循环的nums[i],得到差值,如果我们在map中能够找到这个差值,就说明存在两个整数的和为目标值。 如果没有找到,就将当前循环的nums[i]以及下标i放入map中,以便后续查

计算数组的斜率,偏移,R2

模拟Excel中的R2的计算。         public bool fnCheckRear_R2(List<double[]> lRear, int iMinRear, int iMaxRear, ref double dR2)         {             bool bResult = true;             int n = 0;             dou

C# double[] 和Matlab数组MWArray[]转换

C# double[] 转换成MWArray[], 直接赋值就行             MWNumericArray[] ma = new MWNumericArray[4];             double[] dT = new double[] { 0 };             double[] dT1 = new double[] { 0,2 };