当前位置:   article > 正文

LeetCode力扣每日一题(Java):27、移除元素_leecode 27 27. 移除元素 java

leecode 27 27. 移除元素 java

一、题目

二、解题思路

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],也会被视作正确答案。

所以我的想法是,我们要尽量避免在数组中删除元素这种事件复杂度高的操作,所以当元素值和val相同时,我们可以不必将它删除,而是将它和数组的最后一个元素交换位置,同时让数组长度减1

和上一题(上一篇博客)的想法一样:我们定义一个计数器count,来记录交换元素的次数,nums.length - count 即为新数组的长度

值得注意的是:在交换之后,我们不知道换到前面的数是否也等于val,所以还需执行i--

于是我写了如下代码,第一次提交就通过了,而且代码时间效率击败了100%的Java用户,给我整笑了

  1. int count = 0;
  2. for (int i = 0; i < nums.length - count; i++) {
  3. if(nums[i] == val){
  4. int temp = nums[i];
  5. nums[i] = nums[nums.length - count -1];
  6. nums[nums.length - count -1] = temp;
  7. count++;
  8. i--;
  9. }
  10. }
  11. return nums.length - count;

2、官方题解

方法一:双指针

这题官方题解的思路和上一题(上一篇博客)基本一样

  1. class Solution {
  2. public int removeElement(int[] nums, int val) {
  3. int n = nums.length;
  4. int left = 0;
  5. for (int right = 0; right < n; right++) {
  6. if (nums[right] != val) {
  7. nums[left] = nums[right];
  8. left++;
  9. }
  10. }
  11. return left;
  12. }
  13. }
  14. 作者:力扣官方题解
  15. 链接:https://leetcode.cn/problems/remove-element/
  16. 来源:力扣(LeetCode)
  17. 著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

方法二:双指针优化

  1. class Solution {
  2. public int removeElement(int[] nums, int val) {
  3. int left = 0;
  4. int right = nums.length;
  5. while (left < right) {
  6. if (nums[left] == val) {
  7. nums[left] = nums[right - 1];
  8. right--;
  9. } else {
  10. left++;
  11. }
  12. }
  13. return left;
  14. }
  15. }
  16. 作者:力扣官方题解
  17. 链接:https://leetcode.cn/problems/remove-element/
  18. 来源:力扣(LeetCode)
  19. 著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

 

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/IT小白/article/detail/611478
推荐阅读
相关标签
  

闽ICP备14008679号