题解 | #草原牛群集合#

草原牛群集合

https://www.nowcoder.com/practice/6fc74519ff9c44288dbcec5db7345ded

考察数组的双指针遍历。设定快慢指针都从0开始遍历,fast指针一路往后遍历,当fast指针的值和val不一致的时候,说明当前fast指向的值需要被保存,就将其复制到slow指针,并且将slow指针往后移动一个位置。所以当遍历完的时候,slow指针的位置也就是牛群集合的数量。

完整的Java代码如下所示

import java.util.*;


public class Solution {
    /**
     * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
     *
     * 
     * @param nums int整型一维数组 
     * @param val int整型 
     * @return int整型
     */
    public int remove_cows (int[] nums, int val) {
        // write code here
        int slow=0, fast=0;
        while(fast<nums.length){
            if(nums[fast]!=val){
                nums[slow] = nums[fast];
                slow++;
            }
            fast++;
        }
        return slow;
    }
}

全部评论

相关推荐

评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务