首页 > 其他 > 详细

leetCode 27.Remove Element (删除元素) 解题思路和方法

时间:2017-06-17 14:11:35      阅读:291      评论:0      收藏:0      [点我收藏+]

Remove Element 


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.


思路:此题和26题一脉相承,算法上不难,详细如代码所看到的:

public class Solution {
    public int removeElement(int[] nums, int val) {
        int len = nums.length;
        int tempLen = len;
        int step = 0;//每个元素须要向前转移的距离
        for(int i = 0; i < len; i++){
            if(nums[i] == val){
                step++;//若相等步长+1
                tempLen--;//每个相等的元素长度降低1
            }else{
                nums[i-step] = nums[i];//元素前移n个步长
            }
        }
        return tempLen;
    }
}


leetCode 27.Remove Element (删除元素) 解题思路和方法

原文:http://www.cnblogs.com/yutingliuyl/p/7040068.html

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