力扣面试经典150题day1第一题(lc88),第二题(lc27)

文章目录


一、lc88 合并两个有序数组

O((M+N)Log(M+N))时间复杂度

直接把nums2数组拼接到nums1数组后面,再调用sort函数排序,代码如下,需要注意nums1数组长度为0这个特殊情况

java 复制代码
class Solution {
    public void merge(int[] nums1, int m, int[] nums2, int n) {
        if(m==0){
            for(int i=0;i<n;i++){
                nums1[i] = nums2[i];
            }
        }
        else{
            for(int i=0 ; i < n;i++){
                nums1[m+i] = nums2[i];
            }
            Arrays.sort(nums1);
        }
        
    }
}

O(M+N)时间复杂度

逆向考虑问题,设置三个指针i,j,k,分别表示nums1还剩数据长度,nums2还剩数据长度,下一个插入位置,当i,j不为0时,对nums[i-1]和nums2[j-1]进行大小比较,大的插入到nums1[k-1]位置(长度从1开始计算,数组下标从0开始,所以需要减一),再移动i,j,当i,j其中一个插入完毕后循环退出,如果i不为0,表示nums1上还有数据未遍历到,但已经在返回数组上了,不需要额外操作,如果j不为0,遍历nums2剩下的数据插入到nums1前面。

对于从后插入是否会覆盖数据:因为两个数组已经按非递减排序,所以不会

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

二、lc27移除元素

添加辅助数组

遍历nums数组,把非val元素放入辅助数组ans中,遍历完成后,把ans数组的数据放回nums数组前面

java 复制代码
class Solution {
    public int removeElement(int[] nums, int val) {
        
        int n = nums.length-1;
        if(n<0) return 0;
        int k=0;
        int[] ans = new int[n+1];
        for(int i = 0;i<=n;i++){
            if(nums[i]!=val){
                ans[k]=nums[i];
                k++;
            }
        }
        if(k>0){
            for(int i=0;i<k;i++){
                nums[i]=ans[i];
        }
        }
        
        return k;
    }
}

2.原数组拷贝

遍历nums数组,如果取出的num不等于val就进行拷贝,再ans+1,如果相等,继续遍历

此方法本质上为快慢指针,num元素下标为快指针,遍历整个数组,ans为慢指针,为下一个插入非val元素的位置

java 复制代码
class Solution {
    public int removeElement(int[] nums, int val) {
        int ans = 0;
        for(int num: nums) {
            if(num != val) {
                nums[ans] = num;
                ans++;
            }
        }
        return ans;
    }
}

相关推荐
Dream it possible!4 小时前
LeetCode 面试经典 150_哈希表_存在重复元素 II(46_219_C++_简单)
leetcode·面试·散列表
GISer_Jing4 小时前
计算机基础——浏览器、算法、计算机原理和编译原理等
前端·javascript·面试
蒙奇D索大4 小时前
【数据结构】考研数据结构核心考点:二叉排序树(BST)全方位详解与代码实现
数据结构·笔记·学习·考研·算法·改行学it
智驱力人工智能5 小时前
工厂抽烟检测系统 智能化安全管控新方案 加油站吸烟检测技术 吸烟行为智能监测
人工智能·算法·安全·边缘计算·抽烟检测算法·工厂抽烟检测系统·吸烟监测
学学学无无止境5 小时前
组合两个表-力扣
leetcode
Jabes.yang5 小时前
Java求职面试:从Spring Boot到Kafka的技术探讨
java·spring boot·面试·kafka·互联网大厂
程序员爱钓鱼5 小时前
Go语言实战案例——进阶与部署篇:编写Makefile自动构建Go项目
后端·算法·go
_Power_Y6 小时前
Java面试常用算法api速刷
java·算法·面试
艾醒(AiXing-w)6 小时前
大模型面试题剖析:模型微调中冷启动与热启动的概念、阶段与实例解析
人工智能·深度学习·算法·语言模型·自然语言处理