数组划分,双指针

1 移动零

题目链接:https://leetcode.cn/problems/move-zeroes/description/

这道题要在原数组中交换位置,并且还要求算法有稳定性。我们的常规思路是划分数组,用双指针解决。

public static void doubleIndex3(int[] arr){for(int cur = 0,dest = -1 ; cur < arr.length; cur++) {if(arr[cur] != 0) {dest++;if(cur != dest) {swap(arr , cur ,dest);}}}}

我们定义两个指针,desc 和 cur。数组左到desc是非零元素,desc到cur是0元素,0到数组末尾是待处理元素。这里就体现了数组划分。我们用cur遍历整个数组,在遍历过程中未处理元素会被依次添加到0区和非0区。因此,desc指向的是非零元素的最后一个元素。

代码中,要先让desc == -1,防止数组第一个元素是0,如果arr[cur]不为0,那就让desc++,并且,我们提到,数组左边到desc是非0区,所以如果遍历到的不是0,那么就要放到非0区,而放到非0区的做法就是交换desc后一位元素和当前元素的位置。直至遍历完整个数组。

时间复杂度O(n);

空间复杂度O(1);

相同拓展:

移除相同元素:

题目链接:27. 移除元素 - 力扣(LeetCode)
代码展示:
class Solution {public int removeElement(int[] nums, int val) {int desc = -1;int cur = 0;while(cur < nums.length) {if(nums[cur] != val) {desc++;if(cur != desc){int tmp = nums[desc];nums[desc] = nums[cur];nums[cur] = tmp;}cur++;}else{cur++;}}return desc + 1;}
}

解题思路:

题目要求我们移除数组中值为value的元素,并返回其余元素的元素个数,那我们就可以将值为value的元素放到一边,不为value的元素放到另一边。最终返回的个数就是下标desc + 1即可。

2 复写零

题目链接:https://leetcode.cn/problems/duplicate-zeros/

这道题表示对数组原地操作,那我们就不申请数组,用原数组进行互换即可。

代码展示
class Solution {public void duplicateZeros(int[] arr) {int slow = 0;int fast = -1;while(fast < arr.length - 1){if(arr[slow] == 0) {fast = fast + 2;}else{fast++;}if(fast < arr.length - 1){slow++;}}if(fast == arr.length) {fast = arr.length - 2;slow--;arr[arr.length - 1] = 0;}while(slow < fast) {if(arr[slow] == 0){arr[fast--] = 0;arr[fast--] = 0;}else{arr[fast--] = arr[slow];}slow--;}}}
代码分析:

我们用的是双指针;

首先我们要找到最后一个要复写的元素;定义两个快慢指针,当慢指针等于零的时候,那么快指针走两步,慢指针走一步;此时慢指针每走一步都要判断快指针是否到达数组最后。如果到最后,那么慢指针就无需移动。注意点,要将快指针的起始值设置为1.

这个时候分析案例可知,有个特殊情况,当快指针在倒数第二个位置时,慢指针为0的话,此时快指针会走两步,那么快指针就会越界,这种情况下,当我们在复写的时候,末位置的0不需要复写,因为我们处理完这种特殊情况即可

第三步就是开始复写,每次复写完就将指针减减,直到两个指针相逢,那么此时剩下的元素均不要复写。

3 快乐数

题目链接:. - 力扣(LeetCode)
class Solution {public boolean isHappy(int count) {int slow = count;int fast = value(count);while(fast != slow) {slow = value(slow);fast = value(fast);fast = value(fast);}if(slow == 1) {return true;}return  false;} public static int value(int count){int sum = 0;while (count > 0){int val = count % 10;sum = sum + val * val;count = count / 10;}return sum;}}
代码解析:
这道题类似于判断链表是否循环;

有题可知,一个数经过不断平方求和后都会循环,如果循环数均为1那么返回True,否则返回false。因此我们定义两个变量,一个一次变换两次,一个变换一次,因为形成的是圈,所以每次走两步的变量总会和每次走一步的变量相遇。所以只需要判断二者相遇的时候是否为1即可。

//以下的双指针题的原理通过单调性来实现

4 盛水最多的容器

题目链接:. - 力扣(LeetCode)​​​​​​
思路解析:

这道题要求我们找到数组间距乘以两元素之间乘积的最大值,我们一开始想到的暴力解法一定是将每个可能情况都枚举出来,然后比较。但是当我们稍微思考一下,就能发现,一个指针desc在0位置处,另一个指针cur在1位置,当我们后移cur时由于宽是增大的,所以当cur向后移的元素值大于当前元素值,那结果肯定是增大;我们要求的是最大值,因此当我们将两个指针放置数组两侧的时候,这样宽是最大的,因此在向中心移动过程中一旦遇到比当前值小的时候就能直接跳过。

此时我们要记住一个套路,通过单调性运用双指针的时候,两个指针应该交替都要移动,而不是一个指针固定,只让另一个指针移动;就是说,我们定义的两个指针cur和desc,哪个指针指向的元素小,哪个指针移动。

代码展示:
class Solution {public int maxArea(int[] arr) {int left = 0;int right = arr.length - 1 ;int max = 0;while(left < right){if(max < volume(arr,left,right)){max = volume(arr , left ,right);}if(arr[left] < arr[right]) {int tmp = arr[left];left++;while(left < right && arr[left] < tmp ) {left++;}}else {int tmp = arr[right];right--;while (left < right && arr[right] < tmp) {right--;}}}return max;}public static int volume(int[] arr , int left , int right){if(arr[left] < arr[right]){return arr[left] * (right - left );}else {return arr[right] * (right - left );}}
}

我会分块讲解算法,后续会有动态规划,贪心,回缩,滑动窗口等

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/767739.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

计算机网络(特南鲍姆版) 期末总结

教材《计算机网络&#xff08;第六版&#xff09;》 特南鲍姆版 介绍 互联的可以交换信息的计算机称之为计算机网络&#xff0c;如&#xff1a;英特网 用途 1.访问信息 客户-服务器模型 peer-to-peer system&#xff08;点对点技术&#xff0c;P2P&#xff09; P2P&#xf…

深入理解Linux与Java的IO模型

目录 IO模型Linux的I/O模型Java的I/O模型联系与区别 同步&#xff0c;异步&#xff0c;阻塞&#xff0c;非阻塞同步与异步阻塞与非阻塞Linux I/O模型中的应用Java I/O模型中的应用容易混淆的地方 通过交互理解IO模型用户空间与内核空间Linux I/O模型的交互过程 在软件开发领域&…

加载三维模型,加载时黑的?

JS引擎是单线程 JS和渲染引擎线程无法同时进行&#xff0c;若异步任务和同步任务过多&#xff0c;JS引擎运行&#xff0c;渲染引擎未工作&#xff0c;导致黑黑的

Delphi DataSet转JSon(字符串拼接json)

Delphi中将TDataSet转换为JSon字符串。 function Test.DataSetToJson(ADataset: TDataSet): string; varARecord: string;AField: TField;i: integer; beginResult : ;with ADataset dobegin// 如果dataset是空就退出if IsEmpty thenExit;//初始化ARecordARecord : ;//定义开头…

图论基础|841.钥匙和房间、463. 岛屿的周长

目录 841.钥匙和房间 思路&#xff1a;本题是一个有向图搜索全路径的问题。 只能用深搜&#xff08;DFS&#xff09;或者广搜&#xff08;BFS&#xff09;来搜。 463. 岛屿的周长 841.钥匙和房间 力扣题目链接 (opens new window) 有 N 个房间&#xff0c;开始时你位于 0…

git 常用命令-以及命令解析

一、Push操作 1.先git init 标识仓库地址2.git add xxx git add . 代表添加当前目录所有文件代表标识提交的文件3.git commit -m xxxx 代表git提交后需要说的什么话4.git remote add origin xxxx xxxx替换为github仓库的ssh地址5.git push origin xxx xxx为分支名称如果有报错可…

TCP重传机制详解——03DSACK

TCP重传机制详解——03DSACK 什么是DSACK DSACK是指"Duplicate Selective Acknowledgment"&#xff0c;即重复选择性确认。在TCP通信中&#xff0c;DSACK机制允许接收方向发送方发送有关重复数据包的信息&#xff0c;以帮助发送方更准确地处理重传和丢包情况。 当…

C语言- 输出班级第n个学生的平均成绩

题目描述 输出班级第 n个学生的平均成绩。每个学生有英语、数学、语文、计算机 4 科成绩。若干个学生的 4 门成绩构成一个表格&#xff0c;可以用二维数组储存&#xff0c;每行代表一个学生的 4 门成绩。以为要计算某个学生的平均成绩&#xff0c;需要快速定位到该生成绩的起始…

概率论与数理统计-条件概率题目1-两次取球问题(有放回)

题目&#xff1a; 设袋中装有r只红球,t只白球.每次自袋中任取一只球,观察其颜色例3然后放回,并再放入a只与所取出的那只球同色的球.若在袋中连续取球四次&#xff0c;试求第一、二次取到红球且第三、四次取到白球的概率. 解答&#xff1a; 涉及到条件概率和多次独立事件的概…

ColorWell for Mac 直装激活 非常实用的调色工具

ColorWell 是一款为Mac操作系统设计的实用工具&#xff0c;它旨在帮助用户快速而方便地选择、管理和应用颜色。这款应用程序特别适合设计师、插画师、网页开发者以及任何需要精确颜色匹配的专业人士使用。ColorWell 的核心功能是提供一个简单直观的界面&#xff0c;让用户可以轻…

C++一维数组练习oj(3)

为什么C的一维数组练习要出要做那么多的题目&#xff1f;因为我们是竞赛学生&#xff01;想要将每个知识点灵活运用的话就必须刷大量的题目来锻炼思维。 我使用的是jsswoj.com这个刷题网站&#xff0c;当然要钱... C一维数组练习oj(2)-CSDN博客这是上一次的题目讲解 这道题有…

vscode集成git管理项目

一、git与SVN Git&#xff1a; 是一种分布式版本控制系统&#xff0c;每个开发者都可以在本地完整地复制整个代码仓库&#xff0c;并且可以在不连接到中央服务器的情况下进行提交、分支和合并等操作。 SVN &#xff1a;是一种集中式版本控制系统&#xff0c;开发者们只能直接与…

PwnLab靶场PHP伪协议OSCP推荐代码审计命令劫持命令注入

下载链接&#xff1a;PwnLab: init ~ VulnHub 安装&#xff1a; 打开vxbox直接选择导入虚拟电脑即可 正文&#xff1a; 先用nmap扫描靶机ip nmap -sn 192.168.1.1/24 获取到靶机ip后&#xff0c;对靶机的端口进行扫描&#xff0c;并把结果输出到PwnLab文件夹下&#xff0c;命名…

java每日一题——买啤酒(递归经典问题)

前言&#xff1a; 非常喜欢的一道题&#xff0c;经典中的经典。打好基础&#xff0c;daydayup!!!啤酒问题&#xff1a;一瓶啤酒2元&#xff0c;4个盖子可以换一瓶&#xff0c;2个空瓶可以换一瓶&#xff0c;请问10元可以喝几瓶 题目如下&#xff1a; 啤酒问题&#xff1a;一瓶…

【剑指offer】17. 从尾到头打印链表(java选手)

题目链接 题目链接 题目描述 输入一个链表的头结点&#xff0c;按照 从尾到头 的顺序返回节点的值。 返回的结果用数组存储。 数据范围 0≤ 链表长度 ≤1000。 样例 输入&#xff1a;[2, 3, 5] 返回&#xff1a;[5, 3, 2] 思路 &#xff08;1&#xff09;从头到尾遍历链…

大数据实时计算的Windows功能?

Windows是数据流的时间窗口&#xff0c;流式数据特点就是源源不断没有边界&#xff0c;但是对于我们数据使用者而言很多时候业务要求对特定时间长度的数据进行切片并统计分析&#xff0c;以此来反映通过时间变化某个业务指标的变化情况&#xff0c;这个时候就需要用到流式计算引…

本地部署千问大模型笔记

使用llama.cpp运行大模型&#xff1a; main 命令有一系列参数可选&#xff0c;其中比较重要的参数有&#xff1a; -ins 交互模式&#xff0c;可以连续对话&#xff0c;上下文会保留 -c 控制上下文的长度&#xff0c;值越大越能参考更长的对话历史&#xff08;默认&#xff1a…

进程和线程,线程实现的几种基本方法

什么是进程&#xff1f; 我们这里学习进程是为了后面的线程做铺垫的。 一个程序运行起来&#xff0c;在操作系统中&#xff0c;就会出现对应的进程。简单的来说&#xff0c;一个进程就是跑起来的应用程序。 在电脑上我们可以通过任务管理器可以看到&#xff0c;跑起来的应用程…

java锁关键字sychronized

前置知识&#xff1a; 在HotSpot虚拟机中&#xff0c;对象在内存中存储可分为三块区域&#xff1a; 对象头&#xff1a;有MarkWord和Klass Word组成实例数据&#xff1a;里面主要是成员变量对齐填充&#xff1a;不是8的整数倍&#xff0c;则填充 CAS: Compare and Swap是Jav…

3.24 day3 QT

使用手动连接&#xff0c;将登录框中的取消按钮使用ot4版本的连接到自定义的槽函数中&#xff0c;在自定义的槽函数中调用关闭函数 将登录按钮使用qt5版本的连接到自定义的槽函数中&#xff0c;在槽函数中判断u界面上输入的账号是否为"admin"&#xff0c;密码是否为&…