尧图网站建设 尧图网络
  • 首页
  • 关于我们
  • 服务项目
  • 案例展示
  • 建站流程
  • 资讯中心
  • 联系我们
首页/资讯中心/详情

双指针-左右指针

双指针-左右指针
📅 发布时间:2026/6/19 11:44:45

注意:这里的双指针指的不是C和C++的原生指针(指针数据类型),你可以把这里的指针理解为数组下标,这会帮助你更好地理解本文

概念

左右指针,听名字就知道是两个指针,一个在左,一个在右。左右指针特别适用于处理数组和字符串问题。和快慢指针不同,左右指针同时从两边向中间移动,形成对称扫描。

二分法,二分查找是对左右指针最直接的运用(起码看上去比较像)

初始状态->左指针为 0 ,右指针为 n - 1

终止条件->左指针大于右指针

基础模板

int l = 0 , r = n - 1; while(l < n){ if(){ //当左边满足条件 l++; } if(){ //当右边满足条件 r--; } }

例题

两数之和

167. 两数之和 II - 输入有序数组https://leetcode.cn/problems/two-sum-ii-input-array-is-sorted/这是来自力扣的一道题目

题目:给定一个已按非降序的整数数组,请你从数组中找出两个数,让它们的和等于目标数target,假设每个输入有且只有一个解,且不能重复使用相同的元素(注意:这题的下标从 1 开始)

暴力写法

class Solution { public: vector<int> twoSum(vector<int>& numbers, int target) { for(int i = 1 ; i < numbers.lenght() ; i++){ for(int j = i + 1 ; j <= numbers.lenght() ; j++){ if(numbers[i] + numbers[j] == target){ return {i + 1 , j + 1}; } } } return {-1 , -1}; } };

但是很明显,如果你使用暴力的话,复杂度就来到了O(),想都不用想,包超时的

左右指针写法

利用给定数组非降序的特性,我们可以确定左右指针移动的条件:当左右两数和大于 target 时,左指针向右移动;当左右两束小于 target 时,右指针向左移。

class Solution { public: vector<int> twoSum(vector<int>& numbers, int target) { int l = 0 , r = numbers.size() - 1; while(l < r){ if(numbers[l] + numbers[r] < target){ l++; }else if(numbers[l] + numbers[r] > target){ r--; }else{ return {l + 1 , r + 1}; } } return {l , r}; } };

通过双指针,我们就成功地将复杂度降到O(n)了

反转字符串

P5705 【深基2.例7】数字反转

题目描述:输入一个不小于 100 且小于 1000,同时包括小数点后一位的一个浮点数,例如 123.4 ,要求把这个数字翻转过来,变成 4.321 并输出。

输入

123.4

输出

4.321

这道题其实不用双指针也行,因为这道题其实用纯语法知识也可以做

常规写法

#include<iostream> using namespace std; int main(){ float n; cin>>n; int ge,shi,bai,xiao; bai=(int)(n)/100; shi=(int)(n)/10%10; ge=(int)(n)%10; xiao=(int)(n*10)%10; cout<<(float)(xiao+ge/10.0+shi/100.0+bai/1000.0); return 0; }

左右指针写法

#include<iostream> using namespace std; int main(){ string temp; cin >> temp; int l = 0 , r = temp.length() - 1; while(l < r){ char t = temp[l]; temp[l] = temp[r]; temp[r] = t; l++; r--; } cout << temp << endl; return 0; }

这题用左右指针真有点莫名其妙了,其实可以用 swap 函数直接交换,不需要 l 和 r 这两个变量

总结

本文只是对左右指针的概念进行描述,对其过于具体的使用暂不赘述,但左右指针毫无疑问是比较重要的模板之一。

相关新闻

  • EmotiVoice情感语音生成与用户接受度调研
  • EmotiVoice语音合成中的语气疑问句自然表达
  • EmotiVoice支持语音情感迁移至不同音色

最新新闻

  • 2026年乌鲁木齐市PMP培训机构哪家好?官方授权R.E.P.报考指南 - 众智商学院课程中心
  • 跨平台中文字体一致性挑战与PingFangSC字体技术解决方案
  • 告别Mac束缚!3步在Linux上搭建专业iOS开发环境
  • LeRobot实战指南:构建端到端机器人学习系统的5个关键步骤
  • 反序列化漏洞深度解析:从原理到实战攻防
  • LPC2917/19嵌入式开发实战:Flash、SMC与MSCSS子系统深度解析与避坑指南

日新闻

  • 信任的进化:技术实现详解——如何用JavaScript构建博弈论模拟器
  • Terrakube自定义工作流:如何集成OPA、Infracost等工具扩展IaC能力
  • grunt-concurrent快速入门:5分钟学会并行运行Grunt任务

周新闻

  • 3步解锁iOS设备:applera1n激活锁绕过完全指南
  • 39 2026 人工智能证书终极盘点,普通人选 AI 证书可以从这些方向入手
  • Redis 暴露公网有多危险?从端口检查到补救步骤

月新闻

  • 【总结】入门篇:50句话让你记住架构核心概念
  • WeChatMsg技术方案解析:实现Mac微信数据自主管理的完整解决方案
  • WeChatMsg:革新性微信数据备份方案,打造你的专属数字记忆库

关于尧图

  • 公司简介
  • 团队介绍
  • 企业文化
  • 荣誉资质

服务项目

  • 定制开发
  • 电商建站
  • UI 设计
  • 运维服务

快速链接

  • 案例展示
  • 建站流程
  • 常见问题
  • 资讯中心

联系方式

  • 📍北京市朝阳区互联网产业园 A 座 10 层
  • 📞400-888-8888
  • ✉️contact@rkmt.cn
  • 🕐周一至周日 9:00-21:00

© 2024 北京尧图网络科技有限公司 版权所有 | 京 ICP 备 XXXXXXXX 号