矩阵之螺旋矩阵

总体思路:

  • 注意遍历顺序 每次遍历一圈时候不要多加元素

Leetcode54螺旋矩阵

  • 给你一个 mn 列的矩阵 matrix ,请按照 顺时针螺旋顺序 ,返回矩阵中的所有元素。
    public List<Integer> spiralOrder(int[][] matrix) {
LinkedList<Integer> res=new LinkedList<>(); int num=matrix.length*matrix[0].length;//总元素个数
int top=0;
int bottom=matrix.length-1;
int left=0;
int right=matrix[0].length-1;
int offset=1;//偏移量 while(num>=1){
//从左到右 包括上面全部数据
for(int i=left;i<=right && num>=1;i++){
res.add(matrix[top][i]);
num--;
}
//从上到下 最上面元素不包括
for(int i=top+offset;i<=bottom && num>=1;i++){
res.add(matrix[i][right]);
num--;
}
//从右到左 最右边元素不包括
for(int i=right-offset;i>=left && num>=1;i--){
res.add(matrix[bottom][i]);
num--;
}
//从下到上 最上面和最下面元素不包括
for(int i=bottom-offset;i>=top+offset && num>=1;i--){
res.add(matrix[i][left]);
num--;
}
top++;
bottom--;
left++;
right--;
} return res;
}
  • 我采用的是下面这种循环遍历方式

  • 为了对称 也完全可以采取以下遍历方式

  • 但是采用第二种方式 要对最后一行数组进行单独处理(因为无法进入任何一次之前的循环)

  • 而采用第一种遍历方式的话 最后一行就不需要特殊处理啦

Leetcode59螺旋矩阵二

  • 给你一个正整数 n ,生成一个包含 1n2 所有元素,且元素按顺时针顺序螺旋排列的 n x n 正方形矩阵 matrix
 public int[][] generateMatrix(int n) {
int[][] res=new int[n][n]; int num=1;
int target=n*n;
int top=0;
int bottom=n-1;
int left=0;
int right=n-1;
int offset=1;//偏移量 while(num<=target){
//从左到右 包括上面全部数据
for(int i=left;i<=right && num<=target;i++){
res[top][i]=num;
num++;
}
//从上到下 最上面元素不包括
for(int i=top+offset;i<=bottom && num<=target;i++){
res[i][right]=num;
num++;
}
//从右到左 最右边元素不包括
for(int i=right-offset;i>=left && num<=target;i--){
res[bottom][i]=num;
num++;
}
//从下到上 最上面和最下面元素不包括
for(int i=bottom-offset;i>=top+offset && num<=target;i--){
res[i][left]=num;
num++;
}
top++;
bottom--;
left++;
right--;
}
return res;
}
  • 方式二 采用上面第二个图的对称方式来遍历
 public int[][] generateMatrix(int n) {
int[][] res=new int[n][n]; //循环次数
int loop=n/2; //循环起始位置
int loopx=0;
int loopy=0; //偏移量
int offset=1; //填充数字
int count=1; //开始循环
while(loop>0){
int i=loopx;
int j=loopy; //从左到右
for(;j<loopy+n-offset;j++){
res[i][j]=count++;
} //从上到下
for(;i<loopx+n-offset;i++){
res[i][j]=count++;
} //从右到左
for(;j>loopy;j--){
res[i][j]=count++;
} //从下到少年宫
for(;i>loopx;i--){
res[i][j]=count++;
} //一次循环结束
loop--;
loopx+=1;
loopy+=1;
offset+=2;
} //奇数特殊处理
int mid=n/2;
if(n%2==1){
res[mid][mid]=count++;
} return res;
}

Leetcode刷题之螺旋矩阵的更多相关文章

  1. leetcode刷题-59螺旋矩阵2

    题目 给定一个正整数 n,生成一个包含 1 到 n^2 所有元素,且元素按顺时针顺序螺旋排列的正方形矩阵. 思路 与螺旋矩阵题完全一致 实现 class Solution: def generateM ...

  2. leetcode刷题-54螺旋矩阵

    题目 给定一个包含 m x n 个元素的矩阵(m 行, n 列),请按照顺时针螺旋顺序,返回矩阵中的所有元素. 思路 对于每个外层,从左上方开始以顺时针的顺序遍历所有元素.假设当前层的左上角位于(to ...

  3. LeetCode刷题总结-数组篇(中)

    本文接着上一篇文章<LeetCode刷题总结-数组篇(上)>,继续讲第二个常考问题:矩阵问题. 矩阵也可以称为二维数组.在LeetCode相关习题中,作者总结发现主要考点有:矩阵元素的遍历 ...

  4. C#LeetCode刷题-数组

    数组篇 # 题名 刷题 通过率 难度 1 两数之和 C#LeetCode刷题之#1-两数之和(Two Sum) 43.1% 简单 4 两个排序数组的中位数 C#LeetCode刷题之#4-两个排序数组 ...

  5. C#LeetCode刷题-数学

    数学篇 # 题名 刷题 通过率 难度 2 两数相加   29.0% 中等 7 反转整数 C#LeetCode刷题之#7-反转整数(Reverse Integer) 28.6% 简单 8 字符串转整数 ...

  6. leetcode刷题目录

    leetcode刷题目录 1. 两数之和 2. 两数相加 3. 无重复字符的最长子串 4. 寻找两个有序数组的中位数 5. 最长回文子串 6. Z 字形变换 7. 整数反转 8. 字符串转换整数 (a ...

  7. LeetCode刷题指南(字符串)

    作者:CYC2018 文章链接:https://github.com/CyC2018/CS-Notes/blob/master/docs/notes/Leetcode+%E9%A2%98%E8%A7% ...

  8. LeetCode刷题总结-数组篇(上)

    数组是算法中最常用的一种数据结构,也是面试中最常考的考点.在LeetCode题库中,标记为数组类型的习题到目前为止,已累计到了202题.然而,这202道习题并不是每道题只标记为数组一个考点,大部分习题 ...

  9. LeetCode刷题总结-数组篇(下)

    本期讲O(n)类型问题,共14题.3道简单题,9道中等题,2道困难题.数组篇共归纳总结了50题,本篇是数组篇的最后一篇.其他三个篇章可参考: LeetCode刷题总结-数组篇(上),子数组问题(共17 ...

随机推荐

  1. 使用linux 的shell脚本进行sftp文件上传与下载

    一.批量上传: #!/bin/bash #SFTP配置信息 #用户名 USER=root #密码 PASSWORD=5EYS40T04BMF #待上传文件根目录 SRCDIR=/u02/dab/sft ...

  2. (第二章第一部分)TensorFlow框架之文件读取流程

    本章概述:在第一章的系列文章中介绍了tf框架的基本用法,从本章开始,介绍与tf框架相关的数据读取和写入的方法,并会在最后,用基础的神经网络,实现经典的Mnist手写数字识别. 有四种获取数据到Tens ...

  3. 初识python(2)

    目录 引言 数据类型 字典 集合 元组 布尔值 用户交互 格式化输出 运算符 增量赋值 链式赋值 交叉赋值 解压赋值 逻辑运算符 成员运算符 身份运算符 引言 小伙伴们昨天已经讲了一点python的数 ...

  4. python如何data格式和时间戳的转换

    Python 获取几天前的时间 计算几天前并转换为指定格式. import time import datetime # 先获得时间数组格式的日期 threeDayAgo = (datetime.da ...

  5. LeetCode-075-颜色分类

    颜色分类 题目描述:给定一个包含红色.白色和蓝色,一共 n 个元素的数组,原地对它们进行排序,使得相同颜色的元素相邻,并按照红色.白色.蓝色顺序排列. 此题中,我们使用整数 0. 1 和 2 分别表示 ...

  6. ws请求定时

    heartChechInit() {       const _this = this;       // 设置统筹管理       let heartCheck = {         timer: ...

  7. Go redis hash存储结构体

    需求 需要存储用户数据到redis,结构是hash. 然后取出来,自动转成结构体. 结构体 type UserCache struct { Id int64 `json:"id"` ...

  8. jq 全选 全不选

  9. pandas常用操作详解——数据运算(一)

    表与表之间的数据运算 #构建数据集df1=pd.DataFrame(np.random.random(32).reshape(8,4),columns=list('ABCD')) df2=pd.Dat ...

  10. LGP2726题解

    当初 mark 这道题还是因为看到是黑,感觉比较水,然后它现在掉紫了. 不过这题题解居然满了,写一篇给自己看吧. 首先我们有一个思路,就是割掉一条边,然后分别求两颗树的重心. 等等,这好像是CSP原题 ...