书籍转圈打印矩阵(8)0604

题目

给定一个整型矩阵matrix,请按照转圈的方式打印它。

例如:

1 2 3 4

5 6 7 8

9 10 11 12

13 14 15 16

打印结果为:1,2,3,4,8,12,16,15,14,13,9,5,6,7,11,10

额外空间复杂度为O(1)

解答

这道题可以使用矩阵分圈处理法,这个方法适用与所有矩阵处理。

在矩阵中用左上角的坐标(tR,tC)和右下角的坐标(dR,dC)就可以表示一个子矩阵,比如,题目中的矩阵,当(tR,tC)=(0,0)、(dR,dC)=(3,3),表示的子矩阵就是整个矩阵,那么这个子矩阵最外层的部分如下:

1 2 3 4

5 8

9 12

13 14 15 16

如果能把这个子矩阵的外层转圈打印出来,那么在(tR,tC)=(0,0)、(dR,dC)=(3,3)时,打印的结果为:1,2,3,4,8,12,16,15,14,13,9,5。接下来令tR和tC加1,即(tR,tC)=(1,1),令dR和dC减1,(dR,dC)=(2,2),此时表示的子矩阵如下:

6 7

10 11

再把这个子矩阵转圈打印出来,结果为:6,7,11,10。把tR和tC加1,即(tR,tC)=(2,2),令dR和dC减1,即(dR,dC)=(1,1)。如果发现左上角坐标跑到了右下角坐标的右方或下方,整个过程就停止。已经打印的所有结果来连起来就是我们要求的打印结果。

java 复制代码
public void spiralOrderPrint(int[][] matrix){
    int tR = 0;
    int tC = 0;
    int dR = matrix.length - 1 ;
    int dC = matrix[0].length - 1;
    while(tR < dR && tC <= dC ){
        printEdge(matrix,tR++,tC++,dR--,dC--);
    }
}

public void printEdge(int[][] m,int tR,int tC,int dR,int dC){
    if(tR == dR){//子矩阵只有一行时
        for(int i = tC;i<=dC;i++){
            System.out.print(m[tR][i]+ " " );
        }
    }else if(tC == dC){//子矩阵只有一列时
        for(int i = tR; i<= dR;i++){
            System.out.print(m[i][tC] + " ");
        }
    }else{//一般情况
        int curC = tC;
        int curR = tR;
        while(curC != dC){
            System.out.print(m[tR][curC] + " ");
            curC++;
        }
        while(curR != dR){
            System.out.print(m[curR][dC] + " ");
            curR++;
        }
        while(curC != tC){
            System.out.print(m[dR][curC] + " ");
            curC--;
        }
        while(curR != tR){
            System.out.print(m[curR][tC] + " ");
            curR--;
        }
    }
}
相关推荐
小辉同志8 小时前
74. 搜索二维矩阵
c++·leetcode·矩阵·二分查找
战族狼魂14 小时前
40x40 矩阵控制系统
jvm·oracle·矩阵
一只小小的土拨鼠1 天前
【国奖冲刺/全网首发】2026年第十四届“泰迪杯”A、B、C题完整解题思路、代码与高质量论文大合集
c语言·矩阵·数据挖掘
普中科技1 天前
【普中 51-Ai8051 开发攻略】-- 第 10 章 矩阵按键实验
单片机·嵌入式硬件·矩阵·开发板·普中科技·ai8051u·aicube
歪歪歪比巴卜2 天前
2026年AI新媒体运营工具怎么选?核心功能与适用场景解析
大数据·矩阵·新媒体运营
m0_743106462 天前
【3D硬核】四元数(Quaternions)与旋转矩阵(Rotation)——三维空间中的旋转
人工智能·计算机视觉·3d·矩阵·几何学
别或许2 天前
线代中为什么左乘一个列满秩矩阵,不改变矩阵的秩?
人工智能·算法·矩阵
wfbcg2 天前
每日算法练习:LeetCode 54. 螺旋矩阵 ✅
算法·leetcode·矩阵
Star Learning Python2 天前
《简单线性代数》-20260414
线性代数·决策树·机器学习
AI科技星2 天前
v=c 物理理论核心参数转换表达式大全
开发语言·线性代数·算法·数学建模·平面