螺旋矩阵

题目

给定一个包含 m x n 个元素的矩阵(m 行, n 列),请按照顺时针螺旋顺序,返回矩阵中的所有元素。

示例 1:

输入:

    [

         [ 1, 2, 3 ],

         [ 4, 5, 6 ],

         [ 7, 8, 9 ]

    ]

输出: [1,2,3,6,9,8,7,4,5]

示例 2:

输入:

    [

         [1, 2, 3, 4],

         [5, 6, 7, 8],

         [9,10,11,12]

    ]

输出: [1,2,3,4,8,12,11,10,9,5,6,7]

思路

1.判断矩阵是否为空矩阵,如果为空则直接返回。

2.从左向右遍历,行坐标不变,列坐标从小到大,直至该行遍历结束,然后将行坐标自增并判断矩阵是否遍历结束。

3.从上向下遍历,列坐标不变,行坐标从小到大,直至该列遍历完毕,然后将列坐标自减并判断该矩阵是否遍历结束。

4.从左向右遍历,行坐标不变,列坐标从大到小,直至该行遍历结束,然后将行坐标自减并判断矩阵是否遍历结束。

5.从下向上遍历,列坐标不变,行坐标从大到小,直至该列遍历完毕,然后将该列坐标自增并判断是否遍历结束。

6.依次重复2,3,4,5过程,直至整个矩阵遍历完毕。

代码

vector<int> spiralOrder(vector<vector<int>>& matrix) {
vector<int> res;
if (matrix.empty()) return res;
int beginX = 0;
int endX = matrix[0].size() - 1;
int beginY = 0;
int endY = matrix.size() - 1;
while (true)
{
//从左到右
for (int i = beginX; i <= endX; i++)
{
res.push_back(matrix[beginY][i]);
}
if (++beginY > endY)
{
break;
}
//从上到下
for (int i = beginY; i <= endY; ++i) {
res.push_back(matrix[i][endX]);
}
if (beginX > --endX)
{
break;
}
// 从右到左
for (int i = endX; i >= beginX; --i)
{
res.push_back(matrix[endY][i]);
}
if (beginY > --endY)
{
break;
}
// 从下往上
for (int i = endY; i >= beginY; --i)
{
res.push_back(matrix[i][beginX]);
}
if (++beginX > endX)
{
break;
}
}
return res;
}

总结

1.确定好要遍历的矩阵的左上角和右小角的坐标,即确定每一轮遍历的起点和终点。

2.确定每个过程坐标变换的规律。

3.该题情况多了一些,按照要求一步一步分析,就不会有遗漏。

螺旋矩阵 II

题目

给定一个正整数 n,生成一个包含 1 到 n2 所有元素,且元素按顺时针顺序螺旋排列的正方形矩阵。

示例:

输入: 3

输出:

    [

         [ 1, 2, 3 ],

         [ 8, 9, 4 ],

         [ 7, 6, 5 ]

    ]

思路

该题的遍历方法与上个题目一样

代码

vector<vector<int>> generateMatrix(int n) {
vector<vector<int> > res(n, vector<int>(n));
if (n == 0)
{
return res;
}
int beginX = 0;
int endX = n - 1;
int beginY = 0;
int endY = n - 1;
int index = 1;
while (true) {
//从左到右
for (int i = beginX; i <= endX; i++)
{
res[beginY][i] = index++;
}
if (++beginY > endY)
{
break;
}
//从上到下
for (int i = beginY; i <= endY; ++i) {
res[i][endX] = index++;
}
if (beginX > --endX)
{
break;
}
// 从右到左
for (int i = endX; i >= beginX; --i)
{
res[endY][i] = index++;
}
if (beginY > --endY)
{
break;
}
// 从下往上
for (int i = endY; i >= beginY; --i)
{
res[i][beginX] = index++;
}
if (++beginX > endX)
{
break;
}
}
return res;
}

总结

偷了个懒,从上个题目直接拷贝过来,修改一下遍历操作,这个题目就完成了。

万变不离其宗,掌握了方法,题目都是一样的

leetcode腾讯精选练习之螺旋矩阵(八)的更多相关文章

  1. LeetCode 59. Spiral Matrix II (螺旋矩阵之二)

    Given an integer n, generate a square matrix filled with elements from 1 to n2 in spiral order. For ...

  2. LeetCode OJ:Spiral MatrixII(螺旋矩阵II)

    Given an integer n, generate a square matrix filled with elements from 1 to n2 in spiral order. For ...

  3. LeetCode OJ:Spiral Matrix(螺旋矩阵)

    Given a matrix of m x n elements (m rows, n columns), return all elements of the matrix in spiral or ...

  4. leetcode腾讯精选练习(50 题)(持续更新)

    1.除自身以外数组的乘积 给定长度为 n 的整数数组 nums,其中 n > 1,返回输出数组 output ,其中 output[i] 等于 nums 中除 nums[i] 之外其余各元素的乘 ...

  5. LeetCode 腾讯精选50题--二叉树中的最大路径和

    二叉树中的最大路径和 题目描述 给定一个非空二叉树,返回器最大路径和,路径指一条从任意节点出发,到达任意节点的序列,该路径至少包含一个节点,且不一定经过根节点 解题思路 树这一类数据结构我还不是很熟悉 ...

  6. LeetCode 腾讯精选50题--二叉树的最大深度

    求二叉树的最大深度, 基本思路如下: 设定一个全局变量记录二叉树的深度,利用递归,没遍历一层都将临时深度变量+1,并在每一节点递归结束后判断深度大小. 具体代码如下: package algorith ...

  7. LeetCode 腾讯精选50题--2的幂

    在二进制中,2的幂的数字用二进制表示时只会有一位表示为1,其余都为0,基于这个前提,可以有两种方案: 1. 做位移操作 2. 与数值取反并与原数值做与操作,判断是否与原来的数值相同 对于方案1,我的想 ...

  8. LeetCode 腾讯精选50题--求众数

    由于众数是指数组中相同元素的个数超过数组长度的一半,所以有两种思路,一. 先排序,后取排序后的数组的中间位置的值:二. 统计,设定一个变量统计相同元素出现的次数,遍历数组,若与选定的元素相同,统计变量 ...

  9. LeetCode 腾讯精选50题--只出现一次数字

    事先说明,如果不是评论区的大牛一语点破,我可能还会陷在死胡同里出不来,这道题其实很简单,利用了任何一个学过二进制的人都了解的定理,即: 1. 异或操作满足交换律 : a ^ b ^ c 等价于 a ^ ...

随机推荐

  1. ideaic快捷键

    Intellij IDEA中有很多快捷键让人爱不释手,stackoverflow上也有一些有趣的讨论.每个人都有自己的最爱,想排出个理想的榜单还真是困难.以前也整理过Intellij的快捷键,这次就按 ...

  2. (1)51单片机NOP指令

    提问:什么是NOP指令?干什么用的?单片机程序里执行一条nop指令需要多长时间? (1)一个NOP就是一个机器周期 (2)空指令,延时一个机器周期 (3)这个与单片机型号.指令类型和使用的晶振频率有关 ...

  3. 在网上找到的一些Java封装的utils类

    这是网址:https://github.com/hanyunpeng0521/utils

  4. java面试-泛型

    1.什么是泛型?泛型有什么作用?   泛型就是参数化类型,也就是所操作的数据类型被指定为一个参数.这种参数类型可以用在类.接口和方法的创建中,分别称为泛型类.泛型接口.泛型方法.   在泛型出现之前, ...

  5. 深入ReentrantLock的实现原理和源码分析

    ReentrantLock是Java并发包中提供的一个可重入的互斥锁.ReentrantLock和synchronized在基本用法,行为语义上都是类似的,同样都具有可重入性.只不过相比原生的Sync ...

  6. 【题解】CF1142B Lynyrd Skynyrd(倍增)

    [题解]CF1142B Lynyrd Skynyrd(倍增) 调了一个小时原来是读入读反了.... 求子段是否存在一个排列的子序列的套路是把给定排列看做置换,然后让给定的序列乘上这个置换,问题就转化为 ...

  7. $bzoj2067\ szn$ 二分+贪心

    正解:二分+贪心 解题报告: 传送门$QwQ$ 题目大意就说有一棵树,然后要用若干条线覆盖所有边且不能重叠.问最少要用几条线,在用线最少的前提下最长的线最短是多长. 昂首先最少用多少条线这个还是蛮$e ...

  8. $POJ1742\ Coins$ 多重背包+贪心

    Vjudge传送门 $Sol$ 首先发现这是一个多重背包,所以可以用多重背包的一般解法(直接拆分法,二进制拆分法...) 但事实是会TLE,只能另寻出路 本题仅关注“可行性”(面值能否拼成)而不是“最 ...

  9. Ecshop在模板中判断用户是否登陆,获取用户等级信息

    ecshop模板中smarty怎样判断用户等级.用户id.用户昵称用户名,请看以下方法,使用全局变量 <!-- {if $smarty.session.user_rank gt 1}--> ...

  10. vs2017编译installer项目提示缺少visualstudio2010shell(Integrated)-CHN

    这个问题折腾我一天,欲仙欲死啊~~~~~~! 国内的网站各种百度,都不行. 还是Google大神比较强,在stackoverflow.com找到了解决方法,说来也简单,难者不会,会者不难! ----- ...