顺时针打印矩阵

顺时针打印矩阵

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

顺时针打印矩阵

思路:利用四个边界来控制

import java.util.ArrayList;
public class Solution {
    public ArrayList<Integer> printMatrix(int [][] matrix) {
       if(matrix.length == 0) return null;
       ArrayList<Integer> arrayList = new ArrayList<>();
       int left=0,right=matrix[0].length-1,up=0,down=matrix.length-1;
       while(true){
           for (int i=left;i<=right;i++) arrayList.add(matrix[up][i]);
           if(++up>down) break;
           for (int i=up;i<=down;i++) arrayList.add(matrix[i][right]);
           if(--right<left) break;
           for (int i=right;i>=left;i--) arrayList.add(matrix[down][i]);
           if(--down<up) break;
           for (int i=down;i>=up;i--) arrayList.add(matrix[i][left]);
           if(++left>right) break;
       }
        return arrayList;
    }
}
全部评论

相关推荐

点赞 评论 收藏
分享
服从性笔试吗,发这么多笔,现在还在发。
蟑螂恶霸zZ:傻 x 公司,发两次笔试,两次部门匹配挂,
投递金山WPS等公司10个岗位 >
点赞 评论 收藏
分享
1 收藏 评论
分享
牛客网
牛客企业服务