给你一个由若干 0 和 1 组成的数组 nums 以及整数 k。如果所有 1 都至少相隔 k 个元素,则返回 True ;否则,返回 False 。
示例 1:
输入:nums = [1,0,0,0,1,0,0,1], k = 2
输出:true
解释:每个 1 都至少相隔 2 个元素。
代码
class Solution {
public boolean kLengthApart(int[] nums, int k) {
int com=0;//计算间隔的0
for(int c:nums)
{
if(c==1)
{
if(com>0) return false;//不够k个0
com=k;
}else{
com--;
}
}
return true;
}
}