data:image/s3,"s3://crabby-images/02ace/02ace956f9868cf2a1a780bd2c0a517cd3a46077" alt="JAR search and dependency download from the Maven repository"
g3201_3300.s3245_alternating_groups_iii.readme.md Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of leetcode-in-java21 Show documentation
Show all versions of leetcode-in-java21 Show documentation
Java-based LeetCode algorithm problem solutions, regularly updated
3245\. Alternating Groups III
Hard
There are some red and blue tiles arranged circularly. You are given an array of integers `colors` and a 2D integers array `queries`.
The color of tile `i` is represented by `colors[i]`:
* `colors[i] == 0` means that tile `i` is **red**.
* `colors[i] == 1` means that tile `i` is **blue**.
An **alternating** group is a contiguous subset of tiles in the circle with **alternating** colors (each tile in the group except the first and last one has a different color from its **adjacent** tiles in the group).
You have to process queries of two types:
* queries[i] = [1, sizei]
, determine the count of **alternating** groups with size sizei
.
* queries[i] = [2, indexi, colori]
, change colors[indexi]
to colori
.
Return an array `answer` containing the results of the queries of the first type _in order_.
**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,1,0,1], queries = [[2,1,0],[1,4]]
**Output:** [2]
**Explanation:**
**data:image/s3,"s3://crabby-images/4ca66/4ca667f3b27a59b5400ae7c8db495d6154a3cfc9" alt=""**
First query:
Change `colors[1]` to 0.
data:image/s3,"s3://crabby-images/1ea6d/1ea6dc829ee1785f301a3eb3047e1f1b8e08a00b" alt=""
Second query:
Count of the alternating groups with size 4:
data:image/s3,"s3://crabby-images/cc1c5/cc1c5fa095b36c05e69f2f7aa08f5145b5ef7fad" alt=""data:image/s3,"s3://crabby-images/5415c/5415c96ed98983b7904372266a0c97a1244a1356" alt=""
**Example 2:**
**Input:** colors = [0,0,1,0,1,1], queries = [[1,3],[2,3,0],[1,5]]
**Output:** [2,0]
**Explanation:**
data:image/s3,"s3://crabby-images/f18c3/f18c3e91a5336c0c7fcaf80246de56b2b26475a7" alt=""
First query:
Count of the alternating groups with size 3:
data:image/s3,"s3://crabby-images/42c2a/42c2af1942f2b69c1dc0a7ca6644fa1d94a20073" alt=""data:image/s3,"s3://crabby-images/86d53/86d538e1bf26a3e99a54a691225bbd3bbb29748c" alt=""
Second query: `colors` will not change.
Third query: There is no alternating group with size 5.
**Constraints:**
* 4 <= colors.length <= 5 * 104
* `0 <= colors[i] <= 1`
* 1 <= queries.length <= 5 * 104
* `queries[i][0] == 1` or `queries[i][0] == 2`
* For all `i` that:
* `queries[i][0] == 1`: `queries[i].length == 2`, `3 <= queries[i][1] <= colors.length - 1`
* `queries[i][0] == 2`: `queries[i].length == 3`, `0 <= queries[i][1] <= colors.length - 1`, `0 <= queries[i][2] <= 1`
© 2015 - 2025 Weber Informatics LLC | Privacy Policy