-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathrotate_image.rs
66 lines (63 loc) · 1.16 KB
/
rotate_image.rs
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
61
62
63
64
65
66
///
/// Problem: Rotate Image
///
/// Given an `n x n` 2D matrix representing an image, rotate the image **90 degrees clockwise** in-place.
///
/// **Example 1:**
/// ```plaintext
/// Input:
/// [
/// [1,2,3],
/// [4,5,6],
/// [7,8,9]
/// ]
/// Output:
/// [
/// [7,4,1],
/// [8,5,2],
/// [9,6,3]
/// ]
/// ```
///
/// **Example 2:**
/// ```plaintext
/// Input:
/// [
/// [5,1,9,11],
/// [2,4,8,10],
/// [13,3,6,7],
/// [15,14,12,16]
/// ]
/// Output:
/// [
/// [15,13,2,5],
/// [14,3,4,1],
/// [12,6,8,9],
/// [16,7,10,11]
/// ]
/// ```
///
/// **Constraints:**
/// - `n == matrix.length == matrix[i].length`
/// - `1 <= n <= 20`
/// - `-1000 <= matrix[i][j] <= 1000`
///
/// # Solution:
///
/// - **Time Complexity:** `O(n²)`
/// - **Space Complexity:** `O(1)`
impl Solution {
pub fn rotate(matrix: &mut Vec<Vec<i32>>) {
let n = matrix.len();
for i in 0..n {
for j in i + 1..n {
let temp = matrix[i][j];
matrix[i][j] = matrix[j][i];
matrix[j][i] = temp;
}
}
for row in matrix.iter_mut() {
row.reverse();
}
}
}