data:image/s3,"s3://crabby-images/02ace/02ace956f9868cf2a1a780bd2c0a517cd3a46077" alt="JAR search and dependency download from the Maven repository"
g1901_2000.s1914_cyclically_rotating_a_grid.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-java Show documentation
Show all versions of leetcode-in-java Show documentation
Java-based LeetCode algorithm problem solutions, regularly updated
1914\. Cyclically Rotating a Grid
Medium
You are given an `m x n` integer matrix `grid`, where `m` and `n` are both **even** integers, and an integer `k`.
The matrix is composed of several layers, which is shown in the below image, where each color is its own layer:
data:image/s3,"s3://crabby-images/3a078/3a0781951768900fe55c0d1838e36c85ee5ba769" alt=""
A cyclic rotation of the matrix is done by cyclically rotating **each layer** in the matrix. To cyclically rotate a layer once, each element in the layer will take the place of the adjacent element in the **counter-clockwise** direction. An example rotation is shown below:
data:image/s3,"s3://crabby-images/d13ae/d13ae7e0cebe4f20f60161ee54a69be7537736b6" alt=""
Return _the matrix after applying_ `k` _cyclic rotations to it_.
**Example 1:**
data:image/s3,"s3://crabby-images/faeeb/faeebf57f6db87f7fd0a080da85bd3ba6f97e5ce" alt=""
**Input:** grid = [[40,10],[30,20]], k = 1
**Output:** [[10,20],[40,30]]
**Explanation:** The figures above represent the grid at every state.
**Example 2:**
**data:image/s3,"s3://crabby-images/bb5ee/bb5ee25a567383bd4b52ee1b7133e74596e9ef26" alt=""** **data:image/s3,"s3://crabby-images/59ff7/59ff7535cff16683ac9228e811953bc01289c3c8" alt=""** **data:image/s3,"s3://crabby-images/1c32a/1c32a5dee9199c7a86c15a0cac3ebf9a250ae05e" alt=""**
**Input:** grid = [[1,2,3,4],[5,6,7,8],[9,10,11,12],[13,14,15,16]], k = 2
**Output:** [[3,4,8,12],[2,11,10,16],[1,7,6,15],[5,9,13,14]]
**Explanation:** The figures above represent the grid at every state.
**Constraints:**
* `m == grid.length`
* `n == grid[i].length`
* `2 <= m, n <= 50`
* Both `m` and `n` are **even** integers.
* `1 <= grid[i][j] <= 5000`
* 1 <= k <= 109
© 2015 - 2025 Weber Informatics LLC | Privacy Policy