leet-code/src/main/java/leetcode/editor/cn/ReshapeTheMatrix.java

78 lines
2.1 KiB
Java
Raw Normal View History

2021-07-09 15:21:23 +08:00
//在MATLAB中有一个非常有用的函数 reshape它可以将一个矩阵重塑为另一个大小不同的新矩阵但保留其原始数据。
//
// 给出一个由二维数组表示的矩阵以及两个正整数r和c分别表示想要的重构的矩阵的行数和列数。
//
// 重构后的矩阵需要将原始矩阵的所有元素以相同的行遍历顺序填充。
//
// 如果具有给定参数的reshape操作是可行且合理的则输出新的重塑矩阵否则输出原始矩阵。
//
// 示例 1:
//
//
//输入:
//nums =
//[[1,2],
// [3,4]]
//r = 1, c = 4
//输出:
//[[1,2,3,4]]
//解释:
//行遍历nums的结果是 [1,2,3,4]。新的矩阵是 1 * 4 矩阵, 用之前的元素值一行一行填充新矩阵。
//
//
// 示例 2:
//
//
//输入:
//nums =
//[[1,2],
// [3,4]]
//r = 2, c = 4
//输出:
//[[1,2],
// [3,4]]
//解释:
//没有办法将 2 * 2 矩阵转化为 2 * 4 矩阵。 所以输出原矩阵。
//
//
// 注意:
//
//
// 给定矩阵的宽和高范围在 [1, 100]。
// 给定的 r 和 c 都是正数。
//
// Related Topics 数组 矩阵 模拟
// 👍 216 👎 0
package leetcode.editor.cn;
//566:重塑矩阵
public class ReshapeTheMatrix {
public static void main(String[] args) {
//测试代码
Solution solution = new ReshapeTheMatrix().new Solution();
solution.matrixReshape(new int[][]{{1,2},{3,4}},1,4);
}
//力扣代码
//leetcode submit region begin(Prohibit modification and deletion)
class Solution {
public int[][] matrixReshape(int[][] mat, int r, int c) {
int x = mat.length;
int y = mat[0].length;
if (x * y != r * c) {
return mat;
}
int[][] arr = new int[r][c];
for (int i = 0; i < x; i++) {
for (int j = 0; j < y; j++) {
int num = i * y + j;
arr[num / c][num % c] = mat[i][j];
}
}
return arr;
}
}
//leetcode submit region end(Prohibit modification and deletion)
}