顺序表算法题 -- 力扣

一、移除元素

移除元素

这个题让我们移除数组nums中值为val的元素,最后返回k(不是val的元素个数)

这样显然我们就不能再创建一个数组来解决这个问题了,只能另辟蹊径

思路:双指针

这里定义两个指针(l1,l2)(l1,l2是整数,通过下标访问数组元素)都指向数组的起始位置,然后循环判断l1指向的元素是否等于val?如果等于,就让l2++;如果不等于,那就将l2的值赋给l1指向的元素,然后l1++,l2++。

这样遍历完数组后,l1的值就是不等于val的元素的个数。

这里以题目中给的案例来分析以下:

nums[l2]等于val(3),l2++;

nums[l2]不等于val(3),nums[l1++]=num[l2++];

nums[l2]不等于val(3),nums[l1++]=num[l2++];

nums[l2]等于val(3),l2++;

跳出循环,次数l1的值就是数据个数k

cpp 复制代码
int removeElement(int* nums, int numsSize, int val) {
    int p1=0,p2=0;
    while(p2<numsSize)
    {
        if(nums[p2]==val)
        {
            p2++;
        }
        else
        {
            nums[p1]=nums[p2];
            p1++;
            p2++;
        }
    }
    return p1;
}

二、删除有序数组的重复项

删除有序数组的重复项

这个题让我们删除非严格递增排列的数组中的重复数字个数,最后返回元素个数k

思路:双指针

定义l1,l2两个指针(与上面一样,l1,l2都是整数,通过下标访问数组元素),这里l1从0开始,l2从1开始

判断nums[l1]是否等于nums[l2]?如果等于,l2++;

如果不等于,l1++后再nums[l1]=num[l2];最后l2++;

循环结束后,l1++就是元素个数k

用题目给的示例来分析一下:

nums[l1]等于nums[l2],l2++;

nums[l1]等于nums[l2],nums[++l1]=nums[l2++];

跳出循环,此时l1=1,l1++就是不同的元素个数。

cpp 复制代码
int removeDuplicates(int* nums, int numsSize) 
{
    int l1 = 0, l2 = 1; 
    while(l2<numsSize)
    {
        if(nums[l1]!=nums[l2])
        {
            l1++;
            nums[l1]=nums[l2];
            l2++;
        }
        else
        {
           l2++;
        }
    }
    return ++l1;
}

三、合并两个有序数组

合并两个有序数组

题目要求合并两个有序数组,合并后是非递减序列,最后返回nums1数组的地址。

思路:三指针

定义三个指针(l1,l2,l3)l1指向nums1数组的最后一个有效数字,l2指向nums2数组的最后一个有效数字,l3指向nums1数组的最后一个位置。 与前面的一样这三个指针也是整数,通过下标访问数组元素。

循环中,如果nums1[l1]>nums2[l2]就让l1 指向的数据存放到l3处,并l1--,l3--;

如果nums1[l1]<=nums2[l2],就让l2指向的数据存放到l3处,并l2-- ,l3--;

还是以题目所给的示例来分析:

nums1[l1]<nums2[l2],执行

nums1[l3]=nums2[l2];l2--;l3--;

nums1[l1]<nums2[l2],执行

nums1[l3]=nums2[l2];l2--;l3--;

现在,nums1[l1]>nums2[l2],执行

nums1[l3]=nums1[l1];l1--;l1--;

nums1[l1]等于nums2[l2],执行

nums1[l3]=nums2[l2];l2--;l3--;

现在,l2已经小于0了,循环结束,这时,nums1数组就是合并好的数组

这里注意,如果l1先小于0,我们就需要吧nums2中剩余的数据赋给数组nums2

cpp 复制代码
void merge(int* nums1, int nums1Size, int m, int* nums2, int nums2Size, int n) {
    int l1=m-1,l2=n-1,l3=m+n-1;
    while(l1>=0&&l2>=0)
    {
        if(nums1[l1]>nums2[l2])
        {
            nums1[l3]=nums1[l1];
            l1--;
            l3--;
        }
        else
        {
            nums1[l3]=nums2[l2];
            l2--;
            l3--;
        }
    }
    if(m==0)
    {
        nums1[l3]=nums2[l2];
    }
    if(l2>=0)
    {
        while(l2>=0)
        {
            nums1[l3]=nums2[l2];
            l2--;
            l3--;
        }
    }
}

如果本篇内容对你有帮助,可以一键三连支持一下!!!

如有错误的地方,也请各位大佬们指出纠正

相关推荐
AI进化营-智能译站11 分钟前
ROS2 C++开发系列16-智能指针管理传感器句柄|告别ROS2节点内存泄漏与野指针
java·c++·算法·ai
CS创新实验室44 分钟前
从盘边到芯端——硬盘接口七十年变迁史
算法·磁盘调度
xvhao20131 小时前
单源、多源最短路
数据结构·c++·算法·深度优先·动态规划·图论·图搜索算法
MATLAB代码顾问1 小时前
多种群协同进化算法(MPCE)求解大规模作业车间调度问题——附MATLAB代码
开发语言·算法·matlab
FQNmxDG4S1 小时前
JVM内存模型详解:堆、栈、方法区与垃圾回收
java·jvm·算法
We་ct2 小时前
LeetCode 72. 编辑距离:动态规划经典题解
前端·算法·leetcode·typescript·动态规划
AI科技星2 小时前
精细结构常数α作为SI 7大基本量纲统一耦合常数的量子几何涌现理论
算法·机器学习·数学建模·数据挖掘·量子计算
txzrxz3 小时前
动态规划——背包问题
算法·动态规划
Yingye Zhu(HPXXZYY)3 小时前
洛谷 P15553 [CCPC 2025 哈尔滨站] 液压机
算法
谭欣辰3 小时前
LCS(最长公共子序列)详解
开发语言·c++·算法