这是悦乐书的第264次更新,第277篇原创

01 看题和准备

今天介绍的是LeetCode算法题中Easy级别的第131题(顺位题号是566)。在MATLAB中,有一个非常有用的函数叫做'reshape',它可以将矩阵重新整形为一个不同大小的矩阵,但保留其原始数据。您将获得一个由二维数组表示的矩阵,以及两个正整数r和c,分别表示所需重新整形矩阵的行号和列号。重新形成的矩阵需要以相同的行遍历顺序填充原始矩阵的所有元素。如果具有给定参数的“重塑”操作是可能且合法的,则输出新的重新整形矩阵;否则,输出原始矩阵。例如:

输入:nums = [[1,2],[3,4]],r = 1,c = 4

输出:[[1,2,3,4]]

说明:行遍历的是[1,2,3,4]。新的重新形状矩阵是1 x 4矩阵,使用前面的列表逐行填充。

输入:nums = [[1,2],[3,4]],r = 2,c = 4

输出:[[1,2],[3,4]]

说明:无法将2 x 2矩阵重塑为2 x 4矩阵。所以输出原始矩阵。

注意:

  • 给定矩阵的高度和宽度在[1,100]范围内。

  • 给定的r和c都是正数。

本次解题使用的开发工具是eclipse,jdk使用的版本是1.8,环境是win7 64位系统,使用Java语言编写和测试。

02 第一种解法

题目要求我们把二维数组,根据给出的行和列,进行行列互换,不能换就返回原数组。我们需要考虑的是小行大列转成大行小列,或者大行小列转成小行大列这两种情况,两层循环肯定是逃不掉的。

第一种情况:小行大列转成大行小列,循环内部,原数组的数组循环一次,会往新数组里插入同样多的数据,但是会分成(原数组的列/新数组的列c)行。比如原来是2行4列的数组,在第一次内层循环后,会往新数组中插入2行2列,在第二次内层循环的时候,再插入2行2列,变成新数组4行2列。

第二种情况:大行小列转成小行大列,原数组外部循环(新数组的列/原数组的列)次,才能将一行数据写入到新数组中去。比如原来是4行2列的数组,外部循环第二次时,会往新数组中插入1行4列,在第四次外部循环时,再插入1行4列,变成新数组2行4列。

所以,新数组的行列起始值在循环外部,在内层循环里,每次都是列自加1,如果列自加到等于c,那么表明要换行了,此时行再加1,然后列重置为0,直到转换完所有数据。

public int[][] matrixReshape(int[][] nums, int r, int c) {
if (nums.length == 0 || nums.length*nums[0].length != r*c) {
return nums;
}
int[][] result = new int[r][c];
int row = 0;
int col = 0;
for (int i=0; i<nums.length; i++) {
for (int j=0; j<nums[0].length; j++) {
result[row][col] = nums[i][j];
col++;
if (col == c) {
col = 0;
row++;
}
}
}
return result;
}

03 第二种解法

第一种解法的内层循环那里,我们可以观察下,新数组的列col是有周期的,每次都是从0开始,到c结束,然后row就加1,那么我们可不可以利用取余来替换col,因为取余也是具有周期性的,借助col%c来处理列,那么行呢?

行可以看做逢c进一,也就是循环处理c次数据后,row才会加1。所以结合两者,使用一个次数变量count,col的值就变成了count对c取余,row的值就变成了count除以c的商。

public int[][] matrixReshape2(int[][] nums, int r, int c) {
if (nums.length == 0 || nums.length*nums[0].length != r*c) {
return nums;
}
int[][] result = new int[r][c];
int count = 0;
for (int i=0; i<nums.length; i++) {
for (int j=0; j<nums[0].length; j++) {
result[count/c][count%c] = nums[i][j];
count++;
}
}
return result;
}

04 第三种解法

我们也可以使用队列来进行辅助操作,利用队列先进先出的特性。使用一次两层循环,将原数组元素依次入队,然后再使用一次两层循环,将队列中的元素依次出队,插入到新数组中去即可。

public int[][] matrixReshape3(int[][] nums, int r, int c) {
if (nums.length == 0 || nums.length*nums[0].length != r*c) {
return nums;
}
int[][] result = new int[r][c];
Queue<Integer> queue = new LinkedList<Integer>();
for (int i=0; i<nums.length; i++) {
for (int j=0; j<nums[0].length; j++) {
queue.offer(nums[i][j]);
}
}
for (int i=0; i<r; i++) {
for (int j=0; j<c; j++) {
result[i][j] = queue.poll();
}
}
return result;
}

05 小结

算法专题目前已日更超过四个月,算法题文章131+篇,公众号对话框回复【数据结构与算法】、【算法】、【数据结构】中的任一关键词,获取系列文章合集。

以上就是全部内容,如果大家有什么好的解法思路、建议或者其他问题,可以下方留言交流,点赞、留言、转发就是对我最大的回报和支持!

LeetCode算法题-Reshape the Matrix(Java实现)的更多相关文章

  1. LeetCode算法题-Rotate String(Java实现)

    这是悦乐书的第317次更新,第338篇原创 在开始今天的算法题前,说几句,今天是世界读书日,推荐两本书给大家,<终身成长>和<禅与摩托车维修艺术>,值得好好阅读和反复阅读. 0 ...

  2. LeetCode算法题-Rotated Digits(Java实现)

    这是悦乐书的第316次更新,第337篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第185题(顺位题号是788).如果一个数字经过180度旋转后,变成了一个与原数字不同的 ...

  3. LeetCode算法题-Flood Fill(Java实现)

    这是悦乐书的第306次更新,第325篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第173题(顺位题号是733).图像由二维整数数组表示,每个整数表示图像的像素值(从0到 ...

  4. LeetCode算法题-Image Smoother(Java实现)

    这是悦乐书的第282次更新,第299篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第150题(顺位题号是661).给定表示图像灰度的2D整数矩阵M,您需要设计一个平滑器以 ...

  5. LeetCode算法题-Design LinkedList(Java实现)

    这是悦乐书的第300次更新,第319篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第168题(顺位题号是707).设计链表的实现.您可以选择使用单链表或双链表.单链表中的 ...

  6. LeetCode算法题-Design HashMap(Java实现)

    这是悦乐书的第299次更新,第318篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第167题(顺位题号是706).在不使用任何内置哈希表库的情况下设计HashMap.具体 ...

  7. LeetCode算法题-Design HashSet(Java实现)

    这是悦乐书的第298次更新,第317篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第166题(顺位题号是705).不使用任何内建的hash表库设计一个hash集合,应包含 ...

  8. LeetCode算法题-Binary Search(Java实现)

    这是悦乐书的第297次更新,第316篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第165题(顺位题号是704).给定n个元素的排序(按升序)整数数组nums和目标值,编 ...

  9. LeetCode算法题-Employee Importance(Java实现)

    这是悦乐书的第291次更新,第309篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第159题(顺位题号是690).定义员工信息的数据结构,其中包括员工的唯一ID,他的重要 ...

随机推荐

  1. 『玩具装箱TOY 斜率优化DP』

    玩具装箱TOY(HNOI2008) Description P教授要去看奥运,但是他舍不下他的玩具,于是他决定把所有的玩具运到北京.他使用自己的压缩器进行压缩,其可以将任意物品变成一堆,再放到一种特殊 ...

  2. Java导出CSV文件

    以前导出总是用POI导出为Excel文件,后来当我了解到CSV以后,我发现速度飞快. 如果导出的数据不要求格式.样式.公式等等,建议最好导成CSV文件,因为真的很快. 虽然我们可以用Java再带的文件 ...

  3. Linux 的进程间通信:管道

    本文由云+社区发表 作者:邹立巍 版权声明: 本文章内容在非商业使用前提下可无需授权任意转载.发布. 转载.发布请务必注明作者和其微博.微信公众号地址,以便读者询问问题和甄误反馈,共同进步. 微博ID ...

  4. JS引擎线程的执行过程的三个阶段(二)

    继续JS引擎线程的执行过程的三个阶段(一) 内容, 如下: 三. 执行阶段 1. 网页的线程 永远只有JS引擎线程在执行JS脚本程序,其他三个线程只负责将满足触发条件的处理函数推进事件队列,等待JS引 ...

  5. gulp基本设置

    var gulp = require('gulp'); var clean = require('gulp-clean'); var concat = require('gulp-concat'); ...

  6. 关于setState的一些记录

    在看React的官方文档的时候, 发现了这么一句话,State Updates May Be Asynchronous,于是查询了一波相关的资料, 最后归纳成以下3个问题 setState为什么要异步 ...

  7. Python re 模块

    Python re 模块 TOC 介绍 作用 正则表达式语法 贪婪和非贪婪 普通字符和特殊字符 分组(比较重要) re modul level 方法 正则表达式对象 匹配对象 常用例子 注意事项 Ja ...

  8. jQuery.Ajax IE8,9 无效(CORS跨域)

    今天在开发网站的时候,发现一个问题,$.ajax()在 IE8,9 浏览器不起作用,但 Chrome,Firefox ,360,IE10以上等浏览器却是可以的,网上资料很多,查询最后发现是 IE8,9 ...

  9. 微信公众号页面的web页面键盘弹起问题

    今天开发的过程中,遇到了一个小问题,是这样的,  UI的设计稿中有个底部的按钮是相对于屏幕定位的,但是这个页面还有一个输入框:具体情况请看下图: 这就造成了当我们输入框获取焦点的时候,键盘弹起,下面的 ...

  10. TypeScript,初次见面,请多指教 ?

    为什么用 TS ? 说实话,最开始并没有想把 TS 用到实际项目中来,一来是感觉"类型"会限制 JS 的优势(好吧,就是浪写浪惯了):二来听闻 TS + Redux 的酸爽滋味,有 ...