首页 > 其他 > 详细

leetcode: Remove Element

时间:2016-03-27 02:14:46      阅读:112      评论:0      收藏:0      [点我收藏+]

问题描述:

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

Do not allocate extra space for another array, you must do this in place with constant memory.

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

Example:
Given input array?nums?=?[3,2,2,3],?val?=?3

Your function should return length = 2, with the first two elements of?nums?being 2.

原问题链接:https://leetcode.com/problems/remove-element/

?

问题分析

  这个问题需要的是移除给定数组里一个特定的值。和前一个问题类似,用两个数值一个表示当前遍历到的索引,一个用来记录保存当前合法值的索引。具体的实现如下:

?

public class Solution {
    public int removeElement(int[] nums, int val) {
        if(nums == null || nums.length == 0) return 0;
        int i, j = 0;
        for(i = 0, j = 0; i < nums.length; i++) {
            if(nums[i] != val) nums[j++] = nums[i];
        }
        return j;
    }
}

?

?

?

leetcode: Remove Element

原文:http://shmilyaw-hotmail-com.iteye.com/blog/2286463

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!