JZ19 顺时针打印矩阵

顺时针打印矩阵

http://www.nowcoder.com/questionTerminal/9b4c81a02cd34f76be2659fa0d54342a

老老实实按照顺时针跑路。

import java.util.ArrayList;
public class Solution {
    public ArrayList<Integer> printMatrix(int [][] matrix) {
        if(matrix==null||matrix.length==0||matrix[0].length==0)
            return new ArrayList<Integer>();
        int i=0, j=0;
        int n=matrix.length, m=matrix[0].length;
        ArrayList<Integer> ans=new ArrayList<>();
        int index=1;
        while(ans.size()!=n*m){
            while(j<m-index/4){
                ans.add(matrix[i][j]); j++;
            }
            if(ans.size()==n*m) return ans;
            i++; j--; index++;
            while(i<n-index/4){
                ans.add(matrix[i][j]); i++;
            }
            if(ans.size()==n*m) return ans;
            j--; i--; index++;
            while(j>=0+index/4){
                ans.add(matrix[i][j]); j--;
            }
            if(ans.size()==n*m) return ans;
            i--; j++; index++;
            while(i>=0+index/4){
                ans.add(matrix[i][j]); i--;
            }
            if(ans.size()==n*m) return ans;
            j++; i++; index++;            
        }
        return ans;
    }
}
全部评论

相关推荐

合适才能收到offe...:招聘上写这些态度傲慢的就别继续招呼了,你会发现hr和面试官挺神的,本来求职艰难就可能影响一些心态了,你去这种公司面试的话,整个心态会炸的。
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务