顺时针打印矩阵

  刷题时碰到过的一道题,想了一会有点不顺畅,看了下答案,结果跟我的想法有很大重合,然后AC就把这题抛了。悲剧的是今天笔试考了这题的变种,然后思路有点偏执,没有像原来一步一步分解,而是想要憋出巧妙的解,然后就没有然后了。因果报应屡试不爽。

  下面是这题的解,先将题目分解成一圈一圈打印,然后每圈四条边先后打印。

 

import java.util.ArrayList;
public class Solution {
    public ArrayList<Integer> printMatrix(int [][] matrix) {
        ArrayList<Integer> list = new ArrayList<Integer>();
        int c1 = matrix.length;
        int c2 = matrix[0].length;
        if(matrix == null || c1==0 ||c2==0)
            return null;
        int circle = (Math.min(c1, c2)-1)/2+1;
        if(c1==1||c2==1){
            for(int[] i:matrix)
                for(int j:i)
                	list.add(j);
            return list;
        }
        int control = 0;
        while(control < circle){
            for(int i = control;i <= c2-control-1;i++)
                list.add(matrix[control][i]);
            for(int i = control+1;i <= c1-control-1;i++)
                list.add(matrix[i][c2-control-1]);
            for(int i = c2-control-2;i > control&&(c1-control-1)!= control;i--)
                list.add(matrix[c1-control-1][i]);
            for(int i = c1-control-1;i > control &&(c2-control-1)!=control;i--)
                list.add(matrix[i][control]);
            control++;
        }
        return list;
    }
}

  

 

转载于:https://www.cnblogs.com/famiko/p/5904294.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值