一亩三分地论坛

 找回密码
 获取更多干货,去instant注册!

扫码关注一亩三分地公众号
查看: 350|回复: 5
收起左侧

[Leetcode] 数组里面有一道简单的题Remove Element

[复制链接] |试试Instant~ |关注本帖
hunter829 发表于 2015-8-29 02:00:02 | 显示全部楼层 |阅读模式

注册一亩三分地论坛,查看更多干货!

您需要 登录 才可以下载或查看,没有帐号?获取更多干货,去instant注册!

x
我不懂为什么,最后还有一句A[pos++] = A[i],只要找到数组中的值,然后长度减一不就解决问题了吗?


Given an array and a value, remove all instances of that value in place and return the new length.

The order of elements can be changed. It doesn't matter what you leave beyond the new length.

题意是从数组中删除所有指定的元素并返回最后长度, 直接用一个变量记录将要被覆盖的数字的位置即可

[csharp] view plaincopy
class Solution {  
public:  
    int removeElement(int A[], int n, int elem) {  
        // Note: The Solution object is instantiated only once and is reused by each test case.  
        if (n == 0 ) return 0;  
        int len = n;  
        for (int i = 0, pos = 0; i < n; ++i)  
        {  
            if (A[i] == elem)  
                --len;  
            else  
                A[pos++] = A[i];  
        }  
        return len;  
    }  
};  
  
潇洒走一回 发表于 2015-8-29 02:19:31 | 显示全部楼层
最后一句A[pos++] = A[i] 应该是为了满足  remove all instances of that value in place 。 而且java里面,array的长度一旦初始化就是固定的,改变不了的。
回复 支持 反对

使用道具 举报

水逼一枚 发表于 2015-8-29 02:58:19 | 显示全部楼层
长度减一后,没错长度确实变化了,如果我OJ上后台要测试你是否In-place移除了这个元素,我遍历length-1个位置的元素时,还是会发现你的元素在那里,跟我后来OJ比对的答案就不一致了。这样就没法验证你的正确性了。
回复 支持 反对

使用道具 举报

mhwkanon 发表于 2015-8-31 13:55:30 | 显示全部楼层
OJ要求返回的结果是去掉那个值后的结果,长度减一要删除的值还在那里会被检测到
回复 支持 反对

使用道具 举报

 楼主| hunter829 发表于 2015-8-31 14:30:14 | 显示全部楼层
水逼一枚 发表于 2015-8-29 02:58
长度减一后,没错长度确实变化了,如果我OJ上后台要测试你是否In-place移除了这个元素,我遍历length-1个位 ...

oj是啥,新手刷题  请多多指教哈
回复 支持 反对

使用道具 举报

潇洒走一回 发表于 2015-9-1 01:10:31 | 显示全部楼层
hunter829 发表于 2015-8-31 14:30
oj是啥,新手刷题  请多多指教哈

应该是指Online judgement吧
回复 支持 反对

使用道具 举报

本版积分规则

请点这里访问我们的新网站:一亩三分地Instant.

Instant搜索更强大,不扣积分,内容组织的更好更整洁!目前仍在beta版本,努力完善中!反馈请点这里

关闭

一亩三分地推荐上一条 /5 下一条

手机版|小黑屋|一亩三分地论坛声明 ( 沪ICP备11015994号 )

custom counter

GMT+8, 2016-12-11 20:14

Powered by Discuz! X3

© 2001-2013 Comsenz Inc. Design By HUXTeam

快速回复 返回顶部 返回列表