Java 模拟,逐行注释(9ms,73.6MB)
2021年5月16日 09:22
解题思路
对于原来的数组,只需要从右向左逐行处理,把石头放到该放的位置上去就可以了。
- 如果遇到石头,那么挪动石头到可放的位置。
- 如果遇到障碍物,那么更新可放的位置。
代码
###java
class Solution {
public char[][] rotateTheBox(char[][] box) {
int m = box.length, n = box[0].length;
char[][] ans = new char[n][m]; // 用来构建返回值的二维数组
// 首先逐行处理,把石头挪到该放的地方去
for (int i = 0; i < m; ++i) {
// 首先假设当前 i 行可放的位置是 pos
int pos = n - 1;
// 然后从右往左遍历,逐个更新石头的位置
for (int j = n - 1; j >= 0; --j) {
if (box[i][j] == '#') {
// 遇到了石头,先把它放到该放的位置去
box[i][pos--] = '#';
// 确保没有覆盖掉起始位置的石头,然后把挪动前的位置置为 空(.)
if (pos != j - 1) box[i][j] = '.';
}
// 如果遇到了障碍物,那么就更新可放的位置为障碍物的下一个位置(左边)
else if (box[i][j] == '*') pos = j - 1;
}
}
// 然后把更新后的位置映射到返回值中
for (int i = 0; i < m; ++i) {
for (int j = 0; j < n; ++j) {
ans[j][m - 1 - i] = box[i][j];
}
}
return ans;
}
}