2025-03-09 Daily Challenge
Today I have done leetcode's March LeetCoding Challenge with cpp
.
March LeetCoding Challenge 9
Description
Alternating Groups II
You are given a 0-indexed string blocks
of length n
, where blocks[i]
is either
There is a circle of red and blue tiles. You are given an array of integers colors
and an integer k
. The color of tile i
is represented by colors[i]
:
colors[i] == 0
means that tilei
is red.colors[i] == 1
means that tilei
is blue.
An alternating group is every k
contiguous tiles in the circle with alternating colors (each tile in the group except the first and last one has a different color from its left and right tiles).
Return the number of alternating groups.
Note that since colors
represents a circle, the first and the last tiles are considered to be next to each other.
Example 1:
Input: colors = [0,1,0,1,0], k = 3
Output: 3
Explanation:
Alternating groups:
Example 2:
Input: colors = [0,1,0,0,1,0,1], k = 6
Output: 2
Explanation:
Alternating groups:
Example 3:
Input: colors = [1,1,0,1], k = 4
Output: 0
Explanation:
Constraints:
3 <= colors.length <= 105
0 <= colors[i] <= 1
3 <= k <= colors.length
Solution
class Solution {
public:
int numberOfAlternatingGroups(vector<int>& colors, int k) {
int len = colors.size();
int answer = 0;
int count = 1;
int last = colors[0];
for(int i = 1; i < len + k - 1; ++i) {
int index = i % len;
if(colors[index] == last) {
count = 0;
}
count += 1;
if(count >= k) answer += 1;
last = colors[index];
}
return answer;
}
};
// Accepted
// 625/625 cases passed (80 ms)
// Your runtime beats 17.56 % of cpp submissions
// Your memory usage beats 61.38 % of cpp submissions (102.7 MB)