`
love19820823
  • 浏览: 936910 次
文章分类
社区版块
存档分类
最新评论

顺时针打印矩阵

 
阅读更多

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

例如:如果输入如下矩阵:
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、假如不可以 添加围墙,那么我们可以检测 边界,即检测当前打印如果是 角点,那么换方向。

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics