我是靠谱客的博主 顺心仙人掌,这篇文章主要介绍java 顺时针打印矩阵,现在分享给大家,希望可以做个参考。

题目描述

对于一个矩阵,请设计一个算法从左上角(mat[0][0])开始,顺时针打印矩阵元素。

给定int矩阵mat,以及它的维数nxm,请返回一个数组,数组中的元素为矩阵元素的顺时针输出。

测试样例:

[[1,2],[3,4]],2,2
返回:[1,2,4,3]

代码如下:

import java.util.*;

public class Printer {
    public int[] clockwisePrint(int[][] mat, int n, int m) {
        int x1=0,y1=0;
        int x2=n-1,y2=m-1;
        int i,j;
        int len=n*m;
        int arr[]=new int[len];
        int flag=1;
        int count=0;
        while(true){
            if(flag==1){
                for(j=y1;j<=y2;j++){
                    arr[count++]=mat[x1][j];
                }
                if(count==len)break;
                flag=2;
                x1++;
            }else if(flag==2){
                for(i=x1;i<=x2;i++){
                    arr[count++]=mat[i][y2];
                }
                if(count==len)break;
                flag=3;
                y2--;
            }else if(flag==3){
                for(j=y2;j>=y1;j--){
                    arr[count++]=mat[x2][j];
                }
                if(count==len)break;
                flag=4;
                x2--;
            }else{
                for(i=x2;i>=x1;i--){
                    arr[count++]=mat[i][y1];
                }
                if(count==len)break;
                flag=1;
                y1++;
            }
        }
        return arr;
    }
}

 

最后

以上就是顺心仙人掌最近收集整理的关于java 顺时针打印矩阵的全部内容,更多相关java内容请搜索靠谱客的其他文章。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(109)

评论列表共有 0 条评论

立即
投稿
返回
顶部