双指针刷题和总结

news/2025/3/4 15:45:10/

文章目录

  • 双指针
  • LeetCode
  • 反转字符串
    • 题目
    • 题解
    • 代码
  • 删除有序数组中的重复项 II
    • 题目
    • 题解
    • 代码
  • 除字符串中的所有相邻重复项
    • 题目
    • 题解
    • 代码
  • 删除有序数组中的重复项
    • 题目
    • 题解
    • 代码
  • 蓝桥杯
  • 拔河
    • 题解
    • 代码

双指针

1. 同向双指针:两个指针从同一侧开始,按照相同的方向移动。通常用于滑动窗口或需要维护某个区间的问题。
2. 反向双指针:两个指针分别从数据结构的左右两端开始,向中间移动。通常用于有序数组或需要从两端逼近的问题。
3. 快慢指针:两个指针以不同的速度移动,通常用于链表问题或检测循环。

LeetCode

反转字符串

题目

题目链接

题解

1. 很明显这题要用反向双指针,将字符串反过来,就是把字符串第一个字符和最后一个字符交换位置,以此类推就可以将字符串反过来了

代码

class Solution 
{
public:void reverseString(vector<char>& s) {int n = s.size();int l = 0,r = n - 1;while(l < r){swap(s[l],s[r]);l++;r--;}    }
};

删除有序数组中的重复项 II

题目

题目链接

题解

1. 快慢指针,快指针bp=2,慢指针sp = 1,快指针遍历数组一遍,找到sp-1元素和bp元素不等的情况,将++sp替换为bp

1    1    1    2    2    3  
sp-1 sp   bp // bp = sp-1
1    1    1    2    2    3
sp-1 sp        bp // bp != sp-1
1    1    2    2    2    3sp-1  sp        bp // bp != sp-1
1    1    1    2    2    3sp-1  sp        bp // bp != sp-1
1    1    1    2    2    3sp-1 sp       bp

代码

class Solution 
{
public:int removeDuplicates(vector<int>& nums) {int n = nums.size();if(n < 3) return n;int sp = 1,bp = 2;for(bp = 2;bp < n;bp++){if(nums[sp-1] != nums[bp]){nums[++sp] = nums[bp];}} return sp + 1;}
};

除字符串中的所有相邻重复项

题目

题目链接

题解

1. 这题用比较简单,如果栈为空,把元素插入到栈中,再和数组中的元素比较,如果相同就出栈,如果不同就入栈,最后剩余的元素就是答案
2. 但是要返回字符串,如果栈非空就把元素插入到字符串中,最后得到的字符串和答案是相反的,再逆置一下即可

代码

class Solution 
{
public:string removeDuplicates(string s) {// 栈stack<char> sk;for(auto ch : s){if(sk.empty()) sk.push(ch);else {if(sk.top() == ch) sk.pop();else sk.push(ch);}}string s1;while(!sk.empty()){s1.push_back(sk.top());sk.pop();}reverse(s1.begin(),s1.end());return s1;}
};

删除有序数组中的重复项

题目

题目链接

题解

1. 这题用栈也是可以的,先把第一个元素插入到空栈中,再和数组中的元素比较如果相同就不入栈,如果不同就入栈,就可以达到只保留一个数的目的
2. 可以用set去重,但是这题有个坑,不能直接返回n,要去重后把数组中的元素修改为去重后的,可能是它自己也要检测
3. 同向双指针,一个元素不需要去重直接返回,cur指针和i指针如果相同i就往后走,cur不动,如果不相同cur走到下一位置,i位置的指针赋给cur指针(就是直到找到不同的就给cur的下一个位置的指针,达到了不重复的效果)

代码

class Solution 
{
public:int removeDuplicates(vector<int>& nums) {// set去重,还要修改nums中元素的顺序// int m = nums.size();// set<int> st(nums.begin(),nums.end());// int n = st.size();// nums.clear();// for(auto& ch : st) nums.push_back(ch);// return n;int n = nums.size();if(n == 1) return 1;int cur = 0;for(int i = 0;i < n;i++){if(nums[cur] != nums[i]) {cur++;nums[cur] = nums[i];}}cur++;return cur;}
};

蓝桥杯

拔河

题目链接

题解

1. 这题其实可以用枚举算出每一种情况,如果两数的差最小,排序后一定相邻,最好是都开long long不然可能会爆空间

代码

#include <iostream>
#include<algorithm>
#include<vector>
#include<algorithm>
#include<bits/stdc++.h>
using namespace std;const int N = 1e3 + 10;
long long a[N];int main()
{int n;cin >> n;for(int i = 0;i < n;i++) cin >> a[i];vector<long long> ret;for(int i = 0;i < n;i++){long long s = 0;for(int j = i;j < n;j++){s += a[j];ret.push_back(s);}}long long ans = 1e9 + 10;sort(ret.begin(),ret.end());for(int i = 1;i < ret.size();i++){ans = min(ans,ret[i] - ret[i-1]);}cout << ans << '\n';return 0;
}

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

相关文章

字符串--子串匹配

下面给出了子串匹配问题的模板&#xff0c;预处理结束后的代码根据题意编写 dp 预处理目的&#xff1a;得到26个字母在字符串t中首次出现的位置 数组元素表示从从位置 i 开始往后字符 j 第一次出现的位置 class Solution {public boolean isSubsequence(String s, String t)…

【Python】使用库

> 作者&#xff1a;დ旧言~ > 座右铭&#xff1a;松树千年终是朽&#xff0c;槿花一日自为荣。 > 目标&#xff1a;能使用Python一些相关的库。 > 毒鸡汤&#xff1a;有些事情&#xff0c;总是不明白&#xff0c;所以我不会坚持。早安! > 专栏选自&#xff1a;P…

rust基础-宏与方法之间的区别

宏&#xff08;Macros&#xff09; vs 方法&#xff08;Methods&#xff09; 区别方法&#xff08;Methods&#xff09;宏&#xff08;Macros&#xff09;定义方式在 impl 块中定义&#xff0c;绑定到具体类型。通过 macro_rules! 或过程宏定义&#xff0c;生成代码。调用时机…

算法--贪心

贪心 原理经典例题[860. 柠檬水找零](https://leetcode.cn/problems/lemonade-change/description/)[2208. 将数组和减半的最少操作次数](https://leetcode.cn/problems/minimum-operations-to-halve-array-sum/description/)[179. 最大数](https://leetcode.cn/problems/large…

Python 如何实现烟花效果的完整代码

文章精选推荐 1 JetBrains Ai assistant 编程工具让你的工作效率翻倍 2 Extra Icons&#xff1a;JetBrains IDE的图标增强神器 3 IDEA插件推荐-SequenceDiagram&#xff0c;自动生成时序图 4 BashSupport Pro 这个ides插件主要是用来干嘛的 &#xff1f; 5 IDEA必装的插件&…

萤石云+DeepSeek,云边融合助力音视频AI新突破

​过去几周&#xff0c;全世界的人们短时间内感受到了DeepSeek卷起的AI风暴力量&#xff0c;在迎接大模型无所不能的震撼时&#xff0c;各行各业也进入“深度思考”模式&#xff0c;以期点亮自身行业的智慧树。 DeepSeek已在教育、金融、家居等海量场景展现出广泛的应用潜力…

deepseek+mermaid【自动生成流程图】

成果&#xff1a; 第一步打开deepseek官网(或百度版&#xff08;更快一点&#xff09;)&#xff1a; 百度AI搜索 - 办公学习一站解决 第二步&#xff0c;生成对应的Mermaid流程图&#xff1a; 丢给deepseek代码&#xff0c;或题目要求 生成mermaid代码 第三步将代码复制到me…

基础的排序算法下(交换排序和归并排序)

1&#xff1a;交换排序 基本思想&#xff1a;所谓交换&#xff0c;就是根据序列中两个记录键值的⽐较结果来对换这两个记录在序列中的位置 交换排序的特点是&#xff1a;将键值较⼤的记录向序列的尾部移动&#xff0c;键值较小的记录向序列的前部移动。 1&#xff1a;冒泡排序…