阅读视图

发现新文章,点击刷新页面。

Java 模拟,逐行注释(9ms,73.6MB)

解题思路

对于原来的数组,只需要从右向左逐行处理,把石头放到该放的位置上去就可以了。

  • 如果遇到石头,那么挪动石头到可放的位置。
  • 如果遇到障碍物,那么更新可放的位置。

代码

###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;
    }
}
❌