题目考察的知识点是:

数组、双指针

题目解答方法的文字分析:

设定快慢指针都从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 i = 0; // 指向当前要处理的元素
        int j = 0; // 指向下一个要放置元素的位置
        int n = nums.length;
        while (i < n) {
            if (nums[i] != val) {
                nums[j] = nums[i];
                j++;
            }
            i++;
        }
        return j;
    }
}