顺时针打印矩阵

来源:互联网 发布:湖北自考网络助学加分 编辑:程序博客网 时间:2024/04/29 08:37

题目:输入一个矩阵,按照从外向里以顺时针的顺序依次打印出每一个数字。

例如:如果输入如下矩阵:
1   2   3   4
5   6   7   8
9  10 11 12
13 14 15 16
则依次打印出数字1, 2, 3, 4, 8, 12, 16, 15, 14, 13, 9, 5, 6, 7, 11, 10。

网上听说听到包括Autodesk、EMC在内的多家公司在面试或者笔试里采用过这道题。但是看有些人做的,头晕。还是自己弄了弄。
     解题思路(借鉴 迷宫问题):1)在矩阵周围 添加一堵墙 (-1);

                                               2)分为四个方向运动,向右,向下,向左,向右。
                                              3)在碰到墙 或者 已经走过的点, 则改变方向,方向的改变依赖上条的四个方向,依次循环找下一个方向。(而具体方向的执行,表现在 下标的改动)。
                                             4)用printCount计数打印了的点数,也就是 走过的路径长度,而总路径长度是size*size的,如果大于它了,则不需要在往下执行

 

 

920S)NOW53X0}V8U0R)@~[W

1、这是在假定输入的矩阵不会出现-1情况下,如果说可以出现任何数,我们可以添加其他逻辑进行控制,原理是一样的。例如添加一个bool数组标记矩阵的每一个点的走过状态。

2、假如不可以 添加围墙,那么我们可以检测 边界,即检测当前打印如果是  角点,那么换方向。

原创粉丝点击