刷题 41-45

四十一、移除元素

示例 1:

复制代码
输入:nums = [3,2,2,3], val = 3
输出:2, nums = [2,2]
解释:函数应该返回新的长度 2, 并且 nums 中的前两个元素均为 2。你不需要考虑数组中超出新长度后面的元素。例如,函数返回的新长度为 2 ,而 nums = [2,2,3,3] 或 nums = [2,2,0,0],也会被视作正确答案。

示例 2:

复制代码
输入:nums = [0,1,2,2,3,0,4,2], val = 2
输出:5, nums = [0,1,4,0,3]
解释:函数应该返回新的长度 

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

cpp 复制代码
int removeElement(int* nums, int numsSize, int val) {
    int left = 0;  // 定义左指针,初始指向数组的第一个元素
    int right = numsSize;  // 定义右指针,初始指向数组的最后一个元素的下一个位置
    
    while (left < right) {  // 当左指针小于右指针时执行循环
        if (nums[left] == val) {  // 如果左指针指向的元素等于给定值
            nums[left] = nums[right - 1];  // 将右指针指向的元素赋值给左指针指向的位置
            right--;  // 右指针向前移动一位
        } else {
            left++;  // 左指针向后移动一位
        }
    }
    
    return left;  // 返回处理后的数组长度(左指针位置)
}
cpp 复制代码
int removeElement(int* nums, int numsSize, int val) {
    int left = 0;
    for (int right = 0; right < numsSize; right++) {
        if (nums[right] != val) {
            nums[left] = nums[right];
            left++;
        }
    }
    return left;
}
相关推荐
噢,我明白了12 小时前
QueryWrapper的使用
java
Chase_______12 小时前
【Java基础 | 15】集合框架(中):Set、HashSet、TreeSet 与哈希表
java·windows·散列表
摇滚侠12 小时前
Maven 入门+高深 微服务案例 122-125
java·微服务·maven
QuZero12 小时前
Guava Cache Deep Dive
java·后端·算法·guava
随意起个昵称13 小时前
线性dp-LIS题目4(A Twisty Movement)
算法·动态规划
Felven13 小时前
B. Fair Numbers
数据结构·算法
人道领域13 小时前
【LeetCode刷题日记】93.复原IP地址
java·开发语言·算法·leetcode
jarreyer13 小时前
【算法记录1】模型训练问题
算法
Felven13 小时前
D. Friends and the Restaurant
算法
摇滚侠13 小时前
JavaWeb 全套教程 Listener 112-113
java·开发语言·servlet·tomcat·intellij-idea