LeetCode-移除元素(27)&& 合并两个有序数组(88)

1.移除元素(27)

题目描述:

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

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

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

提示:

0 <= nums.length <= 100

0 <= nums[i] <= 50

0 <= val <= 100

思路: 因为这里要删除指定值的数组元素,按照题目的意思就是把要删除的元素放到数组最后即可。然后值得范围是0~100,这样我们就可以想到将和指定值相等的元素赋为101,然后将数组排序,这样要删除的元素都排到数组之后了。感觉这算是一种钻空子的做法。
代码:

java 复制代码
class Solution {
    public int removeElement(int[] nums, int val) {
        int count=0;
       for(int i=0;i<nums.length;i++) {
           if(nums[i]==val) {
               nums[i]=101;
               count++;
           }
       }
        Arrays.sort(nums);

        return nums.length-count;
    }
}

官方题解:

java 复制代码
class Solution {
    public int removeElement(int[] nums, int val) {
        int n = nums.length;
        int left = 0;
        for (int right = 0; right < n; right++) {
            if (nums[right] != val) {
                nums[left] = nums[right];
                left++;
            }
        }
        return left;
    }
}

这是官方给的一种双指针方法。left指向的是最终保存的数组,right是指向待判断的元素,如果元素不和val值相等则添加到最终数组,否则跳过。

2.合并两个有序数组(88)

题目描述:

给你两个按 非递减顺序 排列的整数数组 nums1 和 nums2,另有两个整数 m 和 n ,分别表示 nums1 和 nums2 中的元素数目。

请你 合并 nums2 到 nums1 中,使合并后的数组同样按 非递减顺序 排列。

注意:最终,合并后数组不应由函数返回,而是存储在数组 nums1 中。为了应对这种情况,nums1 的初始长度为 m + n,其中前 m 个元素表示应合并的元素,后 n 个元素为 0 ,应忽略。nums2 的长度为 n 。

思路: 因为最终两个数组元素要保存到第一个数组中,所以从两个数组的末端元素开始比较,更大的元素保存到第一个数组的最后一个空间,然后继续比较,更大元素保存到第一个数组的倒数第二个空间等等依次进行操作。然后一个数组处理完了跳出循环,最后通过一个循环处理另一个数组的元素。

代码:

java 复制代码
class Solution {
    public void merge(int[] nums1, int m, int[] nums2, int n) {
        int k=m+n-1;
        m=m-1;
        n=n-1;
        while(m>=0&&n>=0) {
            if(nums1[m]<=nums2[n]) {
                nums1[k]=nums2[n];
                k--;
                n--;
            } else {
                nums1[k]=nums1[m];
                k--;
                m--;
            }
        }

        while(n>=0) {
            nums1[k]=nums2[n];
            k--;
            n--;
        }

        while(m>=0) {
            nums1[k]=nums1[m];
            k--;
            m--;
        }
    }
}
相关推荐
CoovallyAIHub2 分钟前
RTMPose:重新定义多人姿态估计的“实时”标准!
深度学习·算法·计算机视觉
爱喝茶的小茶17 分钟前
周赛98补题
开发语言·c++·算法
小庞在加油1 小时前
《dlib库中的聚类》算法详解:从原理到实践
c++·算法·机器学习·数据挖掘·聚类
ComputerInBook1 小时前
C++ 标准模板库算法之 transform 用法
开发语言·c++·算法·transform算法
hn小菜鸡7 小时前
LeetCode 377.组合总和IV
数据结构·算法·leetcode
Deepoch8 小时前
Deepoc 大模型:无人机行业的智能变革引擎
人工智能·科技·算法·ai·动态规划·无人机
heimeiyingwang9 天前
【深度学习加速探秘】Winograd 卷积算法:让计算效率 “飞” 起来
人工智能·深度学习·算法
时空自由民.9 天前
C++ 不同线程之间传值
开发语言·c++·算法
ai小鬼头9 天前
AIStarter开发者熊哥分享|低成本部署AI项目的实战经验
后端·算法·架构
小白菜33366610 天前
DAY 37 早停策略和模型权重的保存
人工智能·深度学习·算法