【双指针算法】原地处理数组的双指针算法思想

2024-06-10 08:04

本文主要是介绍【双指针算法】原地处理数组的双指针算法思想,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

移动零

5992587c62f74754b2090e2495778db1.png

题目中已经明确表示不能重新创建数组来辅助解题,因此只能对数组进行原地操作,即双指针算法思想。

算法思想:

题目要求我们将非0元素放在数组的左边,0元素放在数组的右边,同时保持非0元素的相对位置。

这种对数组元素进行分类的题目一般用双指针比较合适。

注意:这里的双指针其实指的是数组元素的索引。

首先我们将待处理数组分为三部分区间:非0区间:[0,dest]      0区间:[dest+1,cur-1]     待处理区间:[cur,n-1] 

cur:用于遍历数组遇到非0元素则停止。dest:用于交换非0元素与0元素。

1、cur = 0, dest = -1

2、cur遇到0元素:++cur

      cur遇到非0元素:swap(a[dest+1], a[cur]),然后++dest,++cur

      当cur>n-1则结束。

1925a07b4d024da4a91876d08b2f7345.png

e93b9b5a307141a99a23a58c8510bc88.png

class Solution {
public:void moveZeroes(vector<int>& nums) {for(int cur = 0, dest = -1;cur < nums.size();cur++){if(nums[cur])swap(nums[cur], nums[++dest]);}}
};

复写零

e3ef473a94cb4530a05b5b218cfde24e.png

 这道题目要求也是就地进行数组操作,使用双指针是合适的。

算法思想:

先根据“异地”操作然后优化成“就地”操作。下图是通过异地操作获取最后一个“复写”的数。

1、dest = -1,cur = 0,判断a[cur]的值

2、判断dest是否越界 dest <= n-1

3、a[cur] == 0则dest += 2    a[cur] != 0则dest++

4、cur++

a69219f9a462436fa565f67b6896fa6e.png

但是这里有一种特殊情况:

9a2dbc180a884a2aa793ae9d0720ea04.png

找到最后一个复写的元素后按照”从后往前“(因为刚开始从前往后的话,会将后面的元素覆盖掉)的顺序对待处理数组进行复写操作。

class Solution {
public:void duplicateZeros(vector<int>& arr) {int cur = 0, dest = -1;int n = arr.size();//先找到最后一个复写的数while( cur < n){if(arr[cur])++dest;elsedest += 2;if(dest >= n-1)break;++cur;}//处理边界情况if(dest == n){arr[n-1] = 0;--cur;dest -= 2;}//最后从后往前复写元素获得所求数组while(cur >= 0){if(arr[cur])arr[dest--] = arr[cur--];else{arr[dest--] = arr[cur];arr[dest--] = arr[cur--];}}}
};

这篇关于【双指针算法】原地处理数组的双指针算法思想的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

电脑提示xlstat4.dll丢失怎么修复? xlstat4.dll文件丢失处理办法

《电脑提示xlstat4.dll丢失怎么修复?xlstat4.dll文件丢失处理办法》长时间使用电脑,大家多少都会遇到类似dll文件丢失的情况,不过,解决这一问题其实并不复杂,下面我们就来看看xls... 在Windows操作系统中,xlstat4.dll是一个重要的动态链接库文件,通常用于支持各种应用程序

SQL Server数据库死锁处理超详细攻略

《SQLServer数据库死锁处理超详细攻略》SQLServer作为主流数据库管理系统,在高并发场景下可能面临死锁问题,影响系统性能和稳定性,这篇文章主要给大家介绍了关于SQLServer数据库死... 目录一、引言二、查询 Sqlserver 中造成死锁的 SPID三、用内置函数查询执行信息1. sp_w

Java对异常的认识与异常的处理小结

《Java对异常的认识与异常的处理小结》Java程序在运行时可能出现的错误或非正常情况称为异常,下面给大家介绍Java对异常的认识与异常的处理,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参... 目录一、认识异常与异常类型。二、异常的处理三、总结 一、认识异常与异常类型。(1)简单定义-什么是

MySQL JSON 查询中的对象与数组技巧及查询示例

《MySQLJSON查询中的对象与数组技巧及查询示例》MySQL中JSON对象和JSON数组查询的详细介绍及带有WHERE条件的查询示例,本文给大家介绍的非常详细,mysqljson查询示例相关知... 目录jsON 对象查询1. JSON_CONTAINS2. JSON_EXTRACT3. JSON_TA

Golang 日志处理和正则处理的操作方法

《Golang日志处理和正则处理的操作方法》:本文主要介绍Golang日志处理和正则处理的操作方法,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考... 目录1、logx日志处理1.1、logx简介1.2、日志初始化与配置1.3、常用方法1.4、配合defer

springboot加载不到nacos配置中心的配置问题处理

《springboot加载不到nacos配置中心的配置问题处理》:本文主要介绍springboot加载不到nacos配置中心的配置问题处理,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑... 目录springboot加载不到nacos配置中心的配置两种可能Spring Boot 版本Nacos

Java空指针异常NullPointerException的原因与解决方案

《Java空指针异常NullPointerException的原因与解决方案》在Java开发中,NullPointerException(空指针异常)是最常见的运行时异常之一,通常发生在程序尝试访问或... 目录一、空指针异常产生的原因1. 变量未初始化2. 对象引用被显式置为null3. 方法返回null

python web 开发之Flask中间件与请求处理钩子的最佳实践

《pythonweb开发之Flask中间件与请求处理钩子的最佳实践》Flask作为轻量级Web框架,提供了灵活的请求处理机制,中间件和请求钩子允许开发者在请求处理的不同阶段插入自定义逻辑,实现诸如... 目录Flask中间件与请求处理钩子完全指南1. 引言2. 请求处理生命周期概述3. 请求钩子详解3.1

Python处理大量Excel文件的十个技巧分享

《Python处理大量Excel文件的十个技巧分享》每天被大量Excel文件折磨的你看过来!这是一份Python程序员整理的实用技巧,不说废话,直接上干货,文章通过代码示例讲解的非常详细,需要的朋友可... 目录一、批量读取多个Excel文件二、选择性读取工作表和列三、自动调整格式和样式四、智能数据清洗五、

SpringBoot如何对密码等敏感信息进行脱敏处理

《SpringBoot如何对密码等敏感信息进行脱敏处理》这篇文章主要为大家详细介绍了SpringBoot对密码等敏感信息进行脱敏处理的几个常用方法,文中的示例代码讲解详细,感兴趣的小伙伴可以了解下... 目录​1. 配置文件敏感信息脱敏​​2. 日志脱敏​​3. API响应脱敏​​4. 其他注意事项​​总结