当前位置:首页 > 力扣 > 力扣27题最优解:巧用左右指针,3分钟攻克原地操作

力扣27题最优解:巧用左右指针,3分钟攻克原地操作

10个月前 (05-13)

题目要求从整数数组中原地移除所有等于给定值 val 的元素,并返回新的数组长度。最终数组的前 n 个位置应为非 val 的元素,且元素的顺序可以改变。例如,输入 nums = [3,2,2,3], val = 3,移除后数组前 2 个元素为 [2,2],返回长度 2。需要注意两个要求:原地修改数组和使用空间复杂度为 O(1) 的算法

力扣27题最优解:巧用左右指针,3分钟攻克原地操作 双指针 力扣 数组 第1张

解题思路与过程

1‌.双指针技巧‌
使用左右两个指针(l 从左向右,r 从右向左)快速定位需要移除的元素。

2‌.交换与覆盖策略‌
当左指针 l 遇到 val 时,将其与右指针 r 指向的元素交换,并将右指针左移,跳过已被处理的元素。这意味着所有等于 val 的元素逐渐被“推”到数组末尾。

3‌.动态调整有效长度‌
每次交换后,数组的有效长度 n 减 1,确保后续循环不会处理末尾已被标记的元素。

‌4.终止条件‌
循环持续直到左指针 l 超过右指针 r,此时所有非 val 元素已集中在数组前 n 个位置。


代码:

class Solution {  
public:  
    int removeElement(vector<int>& nums, int val) {  
        int n = nums.size();          // 初始化有效长度为数组总长  
        int l = 0, r = n - 1;         // 左右指针分别指向数组首尾  
        while (l <= r) {              // 当左指针未越过右指针时循环  
            if (nums[l] == val) {     // 左指针遇到目标值  
                // 交换左指针和右指针的值,将目标值移到数组末尾  
                int tmp = nums[l];  
                nums[l] = nums[r];  
                nums[r] = tmp;  
                r--;                  // 右指针左移,缩小处理范围  
                n--;                  // 有效长度减1,排除末尾的val  
            } else {  
                l++;                  // 左指针右移,保留当前非val元素  
            }  
        }  
        return n;                     // 返回最终有效长度  
    }  
};


原创内容 转载请注明出处

分享给朋友:

相关文章

力扣第1991题:寻找数组的中心索引 如何找到左右和相等的中心索引

力扣第1991题:寻找数组的中心索引 如何找到左右和相等的中心索引

题目解读给定一个整数数组,我们需要找到一个中心索引,使得该索引左侧所有元素的和等于右侧所有元素的和。如果不存在这样的索引,则返回-1。中心索引的定义不包含在左右两侧的和计算中。这个问题考察对数组遍历和...

力扣3112题解法:带时间限制的最短路径问题解析(C++代码)

力扣3112题解法:带时间限制的最短路径问题解析(C++代码)

一、题目解读力扣3112题要求解决带时间限制的最短路径问题:给定一个有向图,节点具有消失时间,需计算从起点到各节点的最短路径,且路径总时间不能超过节点的消失时间。题目难点在于需在传统最短路径算法(如D...

【牛客157题】:反转链表指定区间(虚拟头节点解法)

【牛客157题】:反转链表指定区间(虚拟头节点解法)

一、题目解读牛客第157题要求反转链表中第m到n个节点(包含m和n)的区间,并保持其他节点顺序不变。例如,给定链表1→2→3→4→5,m=2,n=4,应返回1→4→3→2→5。题目重点在于处理边界条件...

力扣LCR074题区间合并算法解析:贪心排序与区间重叠处理

力扣LCR074题区间合并算法解析:贪心排序与区间重叠处理

一、题目解读力扣LCR074题要求对给定的二维区间数组(每个区间由起始点和终止点构成)进行合并,将重叠的区间合并为更宽的区间,最终输出不重叠的合并结果。例如,输入[[1,3],[2,6],[8,10]...

LeetCode 2576题解:双指针法求解最多标记下标(排序+贪心策略)

LeetCode 2576题解:双指针法求解最多标记下标(排序+贪心策略)

一、题目解读LeetCode 2576题要求在一个整数数组中寻找最多可标记的下标对:若 nums[i] * 2 <= nums[j](i ≠ j),则下标 i 和 j 可配对标记。例如,输入 [...

洛谷P1102题解:利用哈希表优化的数对统计 C++代码解析

洛谷P1102题解:利用哈希表优化的数对统计 C++代码解析

一、题目解读洛谷P1102题要求处理一组整数数组与常数C,统计数组中是否存在元素A与B满足A+B=C。用户需输出满足条件的数对数量。题目关键在于快速判断是否存在互补元素,时间复杂度需优化以避免暴力遍历...

发表评论

访客

看不清,换一张

◎欢迎参与讨论,请在这里发表您的看法和观点。