您当前的位置: 首页 >  面试
  • 1浏览

    0关注

    322博文

    0收益

  • 0浏览

    0点赞

    0打赏

    0留言

私信
关注
热门博文

数组中相关面试题

森明帮大于黑虎帮 发布时间:2021-05-09 17:21:23 ,浏览量:1

在这里插入图片描述

系列文章目录

在这里插入图片描述

一、移除元素

移除元素

1.题目描述
  1. 给你一个数组 nums 和一个值 val,你需要 原地 移除所有数值等于 val 的元素,并返回移除后数组的新长度。不要使用额外的数组空间,你必须仅使用 O(1) 额外空间并 原地 修改输入数组。元素的顺序可以改变。你不需要考虑数组中超出新长度后面的元素。
  2. 说明:为什么返回数值是整数,但输出的答案是数组呢?请注意,输入数组是以「引用」方式传递的,这意味着在函数里修改输入数组对于调用者是可见的。 你可以想象内部操作如下: 在这里插入图片描述 在这里插入图片描述 在这里插入图片描述
2.解题思路
  1. 思路1:定义变量如果当前元素 j 与移除元素 val 相同,那么跳过该元素。如果当前元素 xj与移除元素 val 不同,那么我们将其放到下标 j的位置,并让 j自增右移,最终得到的 j 即是答案。 在这里插入图片描述 代码如下:
int removeElement(int* nums, int numsSize, int val)
{
    int i=0;
    int j=0;
    for(i=0;i            
关注
打赏
1664288938
查看更多评论
0.0583s