顺时针打印矩阵
来源:互联网 发布:湖北自考网络助学加分 编辑:程序博客网 时间: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的,如果大于它了,则不需要在往下执行
1、这是在假定输入的矩阵不会出现-1情况下,如果说可以出现任何数,我们可以添加其他逻辑进行控制,原理是一样的。例如添加一个bool数组标记矩阵的每一个点的走过状态。
2、假如不可以 添加围墙,那么我们可以检测 边界,即检测当前打印如果是 角点,那么换方向。
- 顺时针打印矩阵
- 顺时针打印矩阵
- 顺时针打印矩阵
- 顺时针打印矩阵
- 顺时针打印矩阵
- 顺时针打印矩阵
- 顺时针打印矩阵
- 顺时针打印矩阵
- 顺时针打印矩阵
- 顺时针打印矩阵
- 矩阵顺时针打印
- 顺时针打印矩阵
- 顺时针打印矩阵[算法]
- 顺时针打印矩阵
- 顺时针打印矩阵
- 顺时针打印矩阵
- 顺时针打印矩阵
- 顺时针打印矩阵
- Linux内存管理(一)
- 为Qt程序添加资源文件
- 银行系统照片与本人不符 市民办理信贷业务遭拒
- 毕业论文评审意见、导师意见范文、模板
- Check Form
- 顺时针打印矩阵
- mmap详解
- String--formart
- js移除属性
- Linux下framebuffer操作方法
- MySQL几种NET包
- YY-偶然
- 自动更新-下载文件(问题)
- 摩托罗拉发布最新款Android 3.0平板电脑Xoom