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--;
        }
    }
}
相关推荐
Lenyiin20 分钟前
02.06、回文链表
数据结构·leetcode·链表
爪哇学长23 分钟前
双指针算法详解:原理、应用场景及代码示例
java·数据结构·算法
爱摸鱼的孔乙己25 分钟前
【数据结构】链表(leetcode)
c语言·数据结构·c++·链表·csdn
Dola_Pan27 分钟前
C语言:数组转换指针的时机
c语言·开发语言·算法
繁依Fanyi40 分钟前
简易安卓句分器实现
java·服务器·开发语言·算法·eclipse
烦躁的大鼻嘎1 小时前
模拟算法实例讲解:从理论到实践的编程之旅
数据结构·c++·算法·leetcode
C++忠实粉丝1 小时前
计算机网络socket编程(4)_TCP socket API 详解
网络·数据结构·c++·网络协议·tcp/ip·计算机网络·算法
祁思妙想2 小时前
10.《滑动窗口篇》---②长度最小的子数组(中等)
leetcode·哈希算法
用户37791362947552 小时前
【循环神经网络】只会Python,也能让AI写出周杰伦风格的歌词
人工智能·算法
福大大架构师每日一题2 小时前
文心一言 VS 讯飞星火 VS chatgpt (396)-- 算法导论25.2 1题
算法·文心一言