-
Notifications
You must be signed in to change notification settings - Fork 1
/
Day 36.1.txt
60 lines (42 loc) · 1.18 KB
/
Day 36.1.txt
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
1437. Check If All 1's Are at Least Length K Places Away
Given an array nums of 0s and 1s and an integer k, return True if all 1's are at least k places away from each other, otherwise return False.
Example 1:
Input: nums = [1,0,0,0,1,0,0,1], k = 2
Output: true
Explanation: Each of the 1s are at least 2 places away from each other.
Example 2:
Input: nums = [1,0,0,1,0,1], k = 2
Output: false
Explanation: The second 1 and third 1 are only one apart from each other.
Example 3:
Input: nums = [1,1,1,1,1], k = 0
Output: true
Example 4:
Input: nums = [0,1,0,1], k = 1
Output: true
Constraints:
1 <= nums.length <= 105
0 <= k <= nums.length
nums[i] is 0 or 1
class Solution {
public boolean kLengthApart(int[] n, int c) {
if(c==0)
return true;
int i,k=-1;
for(i=0;i<n.length;i++)
{
if(n[i]==1&&k==-1)
k=i;
else if(n[i]==1&&(i-k-1)<c)
{
k=-3;
break;
}
else if(n[i]==1)
{
k=i;
}
}
return k==-3 ? false : true;
}
}