代码随想录刷题-数组双指针

简介: 代码随想录刷题-数组双指针

算法刷题-数组

27. 移除元素-双指针

给你一个数组 nums 和一个值 val,你需要 原地 移除所有数值等于 val 的元素,并返回移除后数组的新长度。

不要使用额外的数组空间,你必须仅使用 O(1) 额外空间并 原地 修改输入数组

元素的顺序可以改变。你不需要考虑数组中超出新长度后面的元素。

思路

双指针:

定义两个指针:慢指针和快指针 ,慢指针指向最终需要返回的结果,快指针指向走在前面的元素

如果快指针位置的值!=val ,那么就给慢指针,同时慢指针+1。

代码

    int removeElement(vector<int>& nums, int val) {
   
        int n=nums.size();
        int slow=0,fast=0;
        for(;fast<n;fast++){
   
            if(nums[fast]!=val){
   
                nums[slow++]=nums[fast];
            }
        }     
        return slow;
    }

26. 删除有序数组中的重复项

给你一个 非严格递增排列 的数组 nums ,请你 原地 删除重复出现的元素,使每个元素 只出现一次 ,返回删除后数组的新长度。元素的 相对顺序 应该保持 一致 。然后返回 nums 中唯一元素的个数。

考虑 nums 的唯一元素的数量为 k ,你需要做以下事情确保你的题解可以被通过:

  • 更改数组 nums ,使 nums 的前 k 个元素包含唯一元素,并按照它们最初在 nums 中出现的顺序排列。nums 的其余元素与 nums 的大小不重要。
  • 返回 k

思路

双指针,遍历一次数组,每次把当前元素nums[i]放入到结果中,然后指针往后走,直到和当前元素不同,此时再进行赋值i=j-1

代码

    int removeDuplicates(vector<int>& nums) {
   
        int pos=0;
        for(int i=0;i<nums.size();i++){
   
            int j=i;
            while(j<nums.size() && nums[j]==nums[i]) j++;
            nums[pos++]=nums[i];
            i=j-1;
        }
        return pos;
    }

283. 移动零-双指针

给定一个数组 nums,编写一个函数将所有 0 移动到数组的末尾,同时保持非零元素的相对顺序。

请注意 ,必须在不复制数组的情况下原地对数组进行操作。

思路

双指针:

可以转换为:将所有非0的数字都放在前面,并且保持顺序不变

快指针走在前面,每次遇到非0的数就给慢指针,直到结束

最后再让慢指针走完,把剩下的都赋值为0即可。

代码

    void moveZeroes(vector<int>& nums) {
   
        int n=nums.size();
        int pos=0;
        for(int i=0;i<n;i++){
   
            int j=i;
            while(j<n &&nums[j]==0) j++;
            if(j<n) nums[pos++]=nums[j];
            i=j;
        }
        while(pos<n) nums[pos++]=0;
    }

844. 比较含退格的字符串-栈

给定 st 两个字符串,当它们分别被输入到空白的文本编辑器后,如果两者相等,返回 true# 代表退格字符。

思路

直接模拟即可:

如果遇到字符,压入栈中

如果不是字符,并且栈中有元素,那么就弹出来。

也可以使用双指针。

代码

    bool backspaceCompare(string s, string t) {
   
        string x, y;
        for (auto c: s) {
   
            if (c == '#') {
   
                if (!x.empty()) x.pop_back();
            } else x.push_back(c);
        }
        for (auto c: t) {
   
            if (c == '#') {
   
                if (!y.empty()) y.pop_back();
            } else y.push_back(c);
        }
        return x == y;
    }

977. 有序数组的平方

给你一个按 非递减顺序 排序的整数数组 nums,返回 每个数字的平方 组成的新数组,要求也按 非递减顺序 排序。

题目

把每个数平方之后排个序即可

或者可以 使用 双指针,最大值只会 产生在 两边,每次只需要 从两边选 较大的即可。

代码

排序

    vector<int> sortedSquares(vector<int>& nums) {
   
        for(int i=0;i<nums.size();i++) nums[i]=nums[i]*nums[i];
        sort(nums.begin(),nums.end());
        return nums;
    }

双指针:

    vector<int> sortedSquares(vector<int>& nums) {
   
        int n=nums.size();
        vector<int> res(n);
        for(int i=0;i<n;i++) nums[i]=nums[i]*nums[i];
        for(int l=0,r=n-1,pos=n-1;l<=r;){
   
            if(nums[l]>nums[r]) res[pos--]=nums[l++];
            else res[pos--]=nums[r--];
        }
        return res;
    }
相关文章
|
19天前
|
C语言
C语言:数组和指针笔试题解析(包括一些容易混淆的指针题目)
C语言:数组和指针笔试题解析(包括一些容易混淆的指针题目)
|
22天前
|
算法 容器
OJ刷题日记:2、双指针(2)
OJ刷题日记:2、双指针(2)
16 0
|
1月前
|
存储 编译器 C语言
函数指针&&数组指针&&数组传参的本质&&字符指针(进阶篇)
函数指针&&数组指针&&数组传参的本质&&字符指针(进阶篇)
数组指针、函数指针、指针数组、函数 指针数组、指针函数详细总结
数组指针、函数指针、指针数组、函数 指针数组、指针函数详细总结
|
5天前
|
算法 测试技术 容器
【刷题】双指针进阶
请看入门篇 :双指针入门
11 0
【刷题】双指针进阶
|
5天前
|
算法 测试技术 容器
【刷题】双指针入门
经过这四道题目的洗礼,我大概对双指针有了初步印象,接下来我会继续努力!!!
44 13
【刷题】双指针入门
|
13天前
|
C++
【C++】一文深入浅出带你参透库中的几种 [ 智能指针 ]及其背后实现原理(代码&图示)
【C++】一文深入浅出带你参透库中的几种 [ 智能指针 ]及其背后实现原理(代码&图示)
|
19天前
指针指向数组
指针指向数组
17 0
|
21天前
|
存储 人工智能 C++
【重学C++】【指针】详解让人迷茫的指针数组和数组指针
【重学C++】【指针】详解让人迷茫的指针数组和数组指针
34 1
|
21天前
|
存储 C语言
指针数组作为main函数的形参
指针数组作为main函数的形参
14 0