package easy.移除元素27;
classSolution {
publicintremoveElement(int[] nums, int val) {
if (nums.length == 0) return0;
//记录删除元素后的数组长度intlen= nums.length;
//循环查询for (inti=0; i < len; i++) {
if (nums[i] == val) {
//如果最后一个数等于val,len--,且最后一个元素不能是当前元素while (i != len - 1 && nums[len - 1] == val) len--;
//如果值相等,将最后一个值赋值给当前
nums[i] = nums[len - 1];
//数组长度-1
len--;
}
}
return len;
}
}
方法2 双指针
思路
如果左指针 left 指向的元素等于 val,此时将右指针 right 指向的元素复制到左指针 left 的位置,然后右指针 right 左移一位。
如果赋值过来的元素恰好也等于 val,可以继续把右指针 right 指向的元素的值赋值过来
(左指针 left 指向的等于 val 的元素的位置继续被覆盖),直到左指针指向的元素的值不等于 val 为止。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 单元测试从入门到精通
· 上周热点回顾(3.3-3.9)
· Vue3状态管理终极指南:Pinia保姆级教程