书籍“之“字形打印矩阵(8)0609

题目

给定一个矩阵matrix,按照"之"字形的方式打印这个矩阵,例如:

1 2 3 4

5 6 7 8

9 10 11 12

"之"字形打印的结果为:1,2,5,9,6,3,4,7,10,11,8,12

1.上坐标(tR,tC)初始为(0,0),先沿着矩阵第一行移动(tC++),当到达第一行最右边的元素后,再沿着矩阵最后一列移动(tR++)。

2.下坐标(dR,dC)初始为(0,0),先沿着矩阵第一列移动(dR++),当到达第一列最下边的元素时,再沿着矩阵最后一行移动(dC++)。

3.上坐标与下坐标同步移动,每次移动后的上坐标与下坐标的连线就是矩阵中的一条斜线,打印斜线上的元素即可。

4.如果上次斜线是从左下向右上打印的,这次一定是从右上向左下打印,反之亦然。

java 复制代码
public void printMatrixZigZag(int[][] matrix){
    int tR = 0;
    int tC = 0;
    int dR = 0;
    int dC = 0;
    int endR = matrix.length - 1;
    int endC = matrix[0].length - 1;
    boolean = fromUp = false;
    while(tR != endR + 1){
        printLevel(matrix,tR,tC,dR,dC,fromUp);
        tR = tC == endC ? tR + 1 : tR;
        tC = tC == endC ? tC : tC + 1;
        dC = dR == endR ? dC + 1 : dC;
        dR = dR == endR ? dR : dR + 1;
        fromUp = !fromUp;
    }
    System.out.println();
}

public void printLevel(int[][] m, int tR, int tC, int dR, int dC,boolean f){
    if(f){
        while(tR != dR + 1){
            System.out.print(m[tR++][tC--] + " ");
        }
    }else{
        while(dR != tR - 1){
            System.out.print(m[dR--][dC++] + " ");
        }
    }
}
相关推荐
励碼11 分钟前
美团完整面经
java·面试·职场和发展·sass·美团
心扬13 分钟前
python数据结构和算法(5)
数据结构·python·算法
异常君26 分钟前
Elasticsearch 集群滚动升级实战 - 保障业务零停机
java·elasticsearch
gogoMark36 分钟前
FaceFusion 技术深度剖析:核心算法与实现机制揭秘
算法
异常君1 小时前
FST 在 Elasticsearch 中的核心应用与性能优化实践
java·elasticsearch·性能优化
周某某~1 小时前
六.原型模式
java·设计模式·原型模式
异常君1 小时前
通过 Elasticsearch 实现分布式事务的可靠方案
java·分布式·elasticsearch
倔强的石头_1 小时前
【数据结构与算法 经典例题】使用队列实现栈(图文详解)
后端·算法
小安同学iter1 小时前
JUC并发编程(四)常见模式
java·开发语言
不再幻想,脚踏实地2 小时前
Linux简单的操作
java·linux·运维·服务器