面试题:顺时针打印矩阵题目:输入一个矩阵,按照从

11 查阅
面试题:顺时针打印矩阵题目:输入一个矩阵,按照从外向里以顺时针的顺序依次打印出每一个数字。例如:如果输入如下矩阵:1 2 3 45 6 7 89 10 11 1213 14 15 16则依次打印出数字

参考答案:

正确答案:

这道题完全没有涉及复杂的数据结构或者高级的算法,看起来是一个很简单的问题。但实际上解决这个问题,会在代码中包含多个循环,并且还需要判断多个边界条件。如果在把问题考虑得很清楚之前就开始写代码,不可避免会越写越混乱。因此解决这个问题的关键在于先要形成清晰的思路,并把复杂的问题分解成若干个简单的问题。
当我们遇到一个复杂问题的时候,可以用图形来帮助我们思考。由于是以从外圈到内圈的顺序依次打印,我们可以把矩阵想象成若干个圈,如图4.3所示。我们可以用一个循环来打印矩阵,每一次打印矩阵

矩阵