news 2026/4/23 12:42:23

双指针-左右指针

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
双指针-左右指针

注意:这里的双指针指的不是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 这两个变量

总结

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

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/15 20:05:48

EmotiVoice语音合成引擎的端到端训练流程揭秘

EmotiVoice语音合成引擎的端到端训练流程揭秘 在智能语音助手越来越“懂人心”的今天&#xff0c;你有没有想过&#xff1a;为什么有些AI读出的话听起来像念经&#xff0c;而另一些却能让你感受到喜悦、愤怒甚至哽咽&#xff1f;背后的关键&#xff0c;早已不再是简单的“把字读…

作者头像 李华
网站建设 2026/4/22 4:56:55

从文本到情感语音:EmotiVoice多情感合成系统全面评测

从文本到情感语音&#xff1a;EmotiVoice多情感合成系统全面评测 在虚拟主播的直播间里&#xff0c;一句“今天真的好开心&#xff01;”如果只是用标准普通话机械念出&#xff0c;观众很难产生共鸣&#xff1b;但如果这句话带着轻快的语调、微微上扬的尾音和恰到好处的呼吸感—…

作者头像 李华
网站建设 2026/4/23 12:38:33

EmotiVoice开源项目的更新日志与未来路线图

EmotiVoice&#xff1a;让语音真正“有情感”的开源TTS引擎 在虚拟偶像直播中突然笑出声的AI主播&#xff0c;在游戏里因受伤而颤抖说话的NPC&#xff0c;或是智能助手用带着关切语气说出“你今天看起来很累”——这些不再是科幻桥段。随着深度学习推动文本转语音&#xff08;T…

作者头像 李华
网站建设 2026/4/11 20:20:23

Kotaemon汽车4S店车型对比问答

Kotaemon汽车4S店车型对比问答系统深度实践 在如今这个信息爆炸的时代&#xff0c;购车者早已不再满足于销售顾问口头介绍的碎片化信息。他们打开手机&#xff0c;一边刷着评测视频&#xff0c;一边在多个品牌之间反复权衡&#xff1a;续航、空间、配置、价格、售后服务……问题…

作者头像 李华
网站建设 2026/4/19 20:32:54

Kotaemon如何避免大模型幻觉?答案在这里

Kotaemon如何避免大模型幻觉&#xff1f;答案在这里 在金融客服中回答“上季度销售冠军是谁”&#xff0c;如果模型随口编出一个根本不存在的员工名字&#xff1b;在医疗咨询场景里&#xff0c;把两种药物的禁忌症搞混——这些都不是简单的错误&#xff0c;而是大模型幻觉带来的…

作者头像 李华
网站建设 2026/4/21 8:36:25

Kotaemon开源框架深度解析:模块化设计提升开发效率

Kotaemon开源框架深度解析&#xff1a;模块化设计提升开发效率 在构建智能对话系统的今天&#xff0c;我们早已不再满足于“问一句答一句”的机械交互。企业需要的是能理解上下文、调用真实服务、基于可靠知识作答的智能体——一个真正意义上的“数字员工”。然而&#xff0c;从…

作者头像 李华