双指针算法(一)

news/2024/9/15 12:09:37/ 标签: 算法, c++, 开发语言, visual studio
一、移动零

题目链接

题目详情:

1.算法分析

这道题采用的算法原理是双指针算法:利用数组下标当做指针。

利用双指针算法的目的就是进行数组划分、数组分块。

我们先定义一个下标cur和一个下标dest。

两个指针的作用:

cur:从左至右的进行遍历数组。

dest:指向已经处理的区间的最后一个非零元素的位置。

这样区间就被分为三块:

已经处理过的区间的非零元素:[0, dest]

已经处理过的区间的为0的元素:[dest + 1, cur - 1]

未处理区间:[cur, size - 1], size是数组长度

2.具体做法

在cur从左到右的遍历过程中:
1.如果cur所指向的元素为0, 就cur++

2.如果cur所指元素不为0, 就swap(dest + 1, cur) , dest++, cur++

3.代码实现

这道题目的代码实现也挺简单,首先让cur指向下标为0的位置, dest指向下标-1的位置,也就是数组第一个元素的前一个位置。

class Solution {
public:void moveZeroes(vector<int>& nums) {//先定义两个下下标,一个指向数组第一个元素的前一个位置//另一个指向数组的第一个元素的位置int dest = -1;int cur = 0;//通过循环遍历数组while(cur < nums.size()){//如果cur所指向的位置为0的话就++curif(nums[cur] == 0){++cur;}//不为零的话就停下,然后交换dest + 1所指向位置的元素以及cur所指向的元素//交换之后++dest,++curelse{swap(nums[dest + 1], nums[cur]);++dest;++cur;}}}
};
二、复写零

题目链接

题目详情:

1.算法分析

这道题和上道题的类型差不多,也是可以使用双指针算法解决的, 但是这个题的难度要比上一个题大一些。

首先,我们看题目的要求,将数组中的每个零都复写一遍,将其余元素右移,复写后被挤出数组范围的元素就舍弃,对数组进行就地修改,也就是不能使用辅助数组。

我们先定义两个下标一个是cur指向数组第一个位置,也就是0下标,还有就是dest指向数组第一个元素的前一个位置,就是-1下标的位置。

2. 具体做法

1.先找到最后一个复写的数

使用cur进行遍历,如果cur所指位置不为0, dest++,否则dest += 2

2.处理边界情况

当初循环后dest == size时, 说明最后一个需要复写的数是0, arr[size - 1] = 0, cur–, dest -= 2

3.从后往前对数组进行复写

1.cur所指位置不为0, 复写一次, arr[dest] = arr[cur] , dest–, cur–

2.cur所指位置为0, 复写两次, arr[dest] = arr[cur], arr[dest - 1] = arr[cur], dest -= 2, cur–

3.代码实现
class Solution {
public:void duplicateZeros(vector<int>& arr) {int dest = -1, cur = 0;int size = arr.size();//先找到最后一个需要复写的数while(dest < size){if(arr[cur] != 0){dest++;}else{dest += 2;}if(dest >= size - 1)break;cur++;}//处理边界情况if(dest == size){arr[size - 1] = 0;cur--;dest -= 2;}//从后往前进行复写while(cur >= 0){if(arr[cur] != 0){arr[dest] = arr[cur];dest--;}else{arr[dest] = arr[cur];arr[dest - 1] = arr[cur];dest -= 2;}cur--;}}
};
三、快乐数

题目链接

题目详情:

1.算法分析

我们先来看题目要求,题目取得很好快乐数,但是对于做题的人快乐不快乐就不一定了。

题目里说到,快乐数就是一直计算这个数的各位的平方和,如果这个数字到最后能够变为1,那么就快乐,否则不快乐。

这道题是比较简单的,也是可以使用我们的双指针算法来进行解决的。

2.具体做法

定义一个快慢指针,实际上就是一个int类型的数字, 快指针一次走两步, 慢指针一次走一步, 我们在尝试计算平方和的时候可以发现,如果它的平方和走到为1 时 ,后面在怎么求也都是1, 如果不是一出了循环那么这个数永远则始终变不到1。

我们先实现一个计算平方和的函数, 然后,慢指针走一步就是调用一次这个函数,快指针一回调用两次这个函数。

3.代码实现
class Solution {
public:void duplicateZeros(vector<int>& arr) {int dest = -1, cur = 0;int size = arr.size();//先找到最后一个需要复写的数while(dest < size){if(arr[cur] != 0){dest++;}else{dest += 2;}if(dest >= size - 1)break;cur++;}//处理边界情况if(dest == size){arr[size - 1] = 0;cur--;dest -= 2;}//从后往前进行复写while(cur >= 0){if(arr[cur] != 0){arr[dest] = arr[cur];dest--;}else{arr[dest] = arr[cur];arr[dest - 1] = arr[cur];dest -= 2;}cur--;}}
};

这篇文章到这里就结束了,先通过这几道例题,介绍一下双指针这个比较灵活并且规律不太好寻找的算法,后面的一篇文章会继续对双指针算法进行探讨。


http://www.ppmy.cn/news/1506101.html

相关文章

Midjourney V6.1更新 | 细节狂魔,绝美人像(附提示词)

前言 Midjourney V6.1版本&#xff0c;堪称细节狂魔&#xff0c;在人像上简直登峰造极&#xff01; 自V6.1版本更新以来我一次次被Midjourney生成的人像震惊到&#xff01;用Midjourney官网分享的提示词微调&#xff0c;生成图像&#xff0c;每一张都绝美&#xff0c;晚上玩到…

LeetCode题练习与总结:查找重复的电子邮箱--182

一、题目描述 SQL Schema > Pandas Schema 表: Person ---------------------- | Column Name | Type | ---------------------- | id | int | | email | varchar | ---------------------- id 是该表的主键&#xff08;具有唯一值的列&#xff0…

【区块链+医疗健康】基于区块链的中药饮片流转质量服务与监管平台 | FISCO BCOS应用案例

有数据显示&#xff0c;医疗机构委托第三方代煎代配业务已经占到医院代煎业务总量的 92.3%。委托代煎业务虽然方便了 医疗机构和患者&#xff0c;但业务过程牵涉处方外流&#xff0c;业务范围从“医院 - 患者”扩展到“医院 - 中药代煎中心 - 物流 - 患者”&#xff0c; 涉及到…

从混沌到秩序:一本书教你掌握互联网内容审核与信息安全的密钥

随着互联网技术的迅猛发展&#xff0c;视频、图片、文字等多媒体内容以前所未有的速度在全球范围内传播与分享&#xff0c;极大地丰富了人们的信息获取渠道和娱乐生活方式。然而&#xff0c;这一繁荣景象背后&#xff0c;也隐藏着内容安全、版权侵犯、虚假信息传播、不良内容泛…

Docker深入讲解

Docker深入讲解 目录 概述Docker基本概念 2.1 什么是Docker2.2 Docker的核心组件2.3 Docker与传统虚拟化技术的比较 Docker安装与配置 3.1 安装Docker3.2 配置Docker3.3 验证Docker安装 Docker镜像 4.1 什么是Docker镜像4.2 获取和管理镜像4.3 Dockerfile的使用4.4 构建镜像 …

react学习笔记:7

预览&#xff1a;&#xff08;fetch发送请求、SPA、连续解构赋值、消息订阅、react router路由第三方库&#xff09; 1、连续解构赋值 总结&#xff1a; 1、连续解构赋值的写法&#xff1a;对象包对象&#xff0c;第二个解构的value一定也是在{}内部的写法 2、消息订阅发布 …

【算法速刷(5/100)】LeetCode —— 20.有效的括号

题目要求比较明晰简洁&#xff0c;编码难度并不算高 下面贴出代码和思路 bool isValid(string s) {stack<char> stk;for(const char& c : s){if(stk.empty()){stk.push(c);continue;}if(c ( || c [ || c {){stk.push(c);continue;}else{char top stk.top();boo…

Python学习(1):使用Python的Dask库实现并行计算

目录 一、Dask介绍 二、使用说明 安装 三、测试 1、单个文件中实现功能 2、运行多个可执行文件 最近在写并行计算相关部分&#xff0c;用到了python的Dask库。 Dask官网&#xff1a;Dask | Scale the Python tools you love 一、Dask介绍 Dask是一个灵活的并行和分布式…

nginx日志解析

Nginx 的日志默认参数包括访问日志&#xff08;Access Log&#xff09;和错误日志&#xff08;Error Log&#xff09;。以下是对这些默认参数的详细解析&#xff1a; 1. 访问日志&#xff08;Access Log&#xff09; 访问日志记录了每个客户端请求的详细信息&#xff0c;包括…

mmdebstrap:创建 Debian 系统 chroot 环境的利器 ️

文章目录 mmdebstrap 的一般性参数说明 &#x1f4dc;mmdebstrap 的常见用法示例 &#x1f308;使用 mmdebstrap 的注意事项 ⚠️ &#x1f308;你好呀&#xff01;我是 山顶风景独好 &#x1f388;欢迎踏入我的博客世界&#xff0c;能与您在此邂逅&#xff0c;真是缘分使然&am…

2017-架构师案例(九)

某软件企业受该省教育部门委托建设高校数字化教育教学资源共享平台&#xff0c;实现以众筹众创的方式组织省内普通高校联合开展教育教学资源内容建设&#xff0c;实现全省优质教学资源整合和共享。该资源共享平台的主要功能模块包括: (1)统一身份认证模块:提供统一的认证入口&…

一、安装go环境以及编译输出HelloWorld

目前的热门技术方向从分布式微服务开始转向云原生而云原生方向需要掌握GO语言&#xff0c;基于此决定利用平时的时间来完成GO语言的学习。 安装&#xff08;基于mac m1&#xff09; &#xff08;翻看了网上很多的资料&#xff0c;发现很多人记录的有很多问题&#xff0c;一个…

左神学习笔记-岛屿数量问题(java版算法)

目录 1. 问题描述2. 解决方法3. 拓展进阶问题4. 参考链接 1. 问题描述 题目&#xff1a;一个矩阵中只有0和1两个值&#xff0c;每个位置都可以和自己的上下左右四个位置相连&#xff0c;如果有一片1连在一起&#xff0c;这一部分叫做一个岛&#xff0c;求一个矩阵中有多少岛&a…

uBlock Origin很快将无法在Chrome上使用 开发者发布情况说明

Chrome v127 版开始扩展程序页面将自动显示即将不再支持的扩展程序&#xff0c;包括知名的广告拦截扩展程序 uBlock Origin 也在谷歌的警告列表中。昨天 uBO 团队发布新的支持文档对目前的情况进行说明&#xff0c;简单来说就是 Chrome 将不再支持基于 Manifest v2 开发的扩展程…

前端构建工具|vite快速入门

认识vite vite组成部分 Vite是一种新型前端构建工具&#xff0c;能够显著提升前端开发体验。它主要由两部分组成&#xff1a; 一个开发服务器&#xff0c;它基于 原生 ES 模块 提供了 丰富的内建功能&#xff0c;如速度快到惊人的 模块热更新&#xff08;HMR&#xff09;。一…

Java-数据库基本概念

数据库DataBase 定义: 保存一组数据的仓库就是数据库 例 BirdBoot项目中&#xff0c;我们为了保存一组用户信息&#xff0c;创建了一个目录users。里面用若干个文件保存每一个用户信息 此时users目录就可以称为是一个数据库 只不过对于这些数据的维护操作&#xff0c;要么…

Internet Download Manager(IDM)2024中文版本有哪些新功能?6.42版本功能介绍

1. Internet Download Manager&#xff08;IDM&#xff09;是一款功能强大的下载管理器&#xff0c;支持所有流行的浏览器&#xff0c;并可提升下载速度高达5倍。 2. IDM具有智能下载逻辑加速器&#xff0c;可以设置文件下载优先级、分块下载等&#xff0c;提高下载效率。 IDM…

gitlab给用户添加项目权限

1.进入管理员界面 2.进入群组 3.添加用户

Vue3 核心模块源码解析

Vue3 核心模块源码解析 1、Vue3 模块源码解析1.1 compiler-core1.1.1 目录结构1.1.2 compile逻辑 1.2 reactivity1.2.1 目录结构1.2.2 reactivity逻辑 1.3 runtime-core1.3.1 目录结构1.3.2 runtime核心逻辑 1.4 runtime-dom1.4.1 主要功能 1.5 runtime-test1.5.1 目录结构1.5.…

力扣——572.另一个树的子树

题目&#xff1a; 思路&#xff1a; 深度优先搜索&#xff0c;遍历root的每一个节点代表的整棵树是否和subroot一样。比较是否一样的时候可以从根节点开始递归&#xff0c;首先查看是否为空&#xff0c;然后值是否一样。 代码&#xff1a; vs可运行代码&#xff1a; &#…