剑指offer之面试题20:顺时针打印矩阵
2016-07-09 17:07
337 查看
题目:
输入一个矩阵,按照从外向里以顺时针的顺序依次打印出每一个数字,例如,如果输入如下矩阵: 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.
思路:
用左上和右下的坐标定位出一次要旋转打印的数据,一次旋转打印结束后,往对角分别前进和后退一个单位。需要加入条件判断,防止出现单行或者单列的情况。
代码:
本文出自 “momo就是辣么萌” 博客,请务必保留此出处http://momo462.blog.51cto.com/10138434/1813841
输入一个矩阵,按照从外向里以顺时针的顺序依次打印出每一个数字,例如,如果输入如下矩阵: 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.
思路:
用左上和右下的坐标定位出一次要旋转打印的数据,一次旋转打印结束后,往对角分别前进和后退一个单位。需要加入条件判断,防止出现单行或者单列的情况。
代码:
class Solution { public: vector<int> printMatrix(vector<vector<int> > matrix) { int columns=matrix[0].size(); int rows=matrix.size(); vector<int> res; if(columns<=0||rows<=0) { return res; } //起始点 // 定义四个关键变量,表示左上和右下的打印范围 int left = 0, top = 0, right = columns - 1, bottom = rows - 1; while (left <= right && top <= bottom) { // left to right for (int i = left; i <= right; ++i) res.push_back(matrix[top][i]); // top to bottom for (int i = top + 1; i <= bottom; ++i) res.push_back(matrix[i][right]); // right to left if (top != bottom) for (int i = right - 1; i >= left; --i) res.push_back(matrix[bottom][i]); // bottom to top if (left != right) for (int i = bottom - 1; i > top; --i) res.push_back(matrix[i][left]); left++,top++,right--,bottom--; } return res; } };
本文出自 “momo就是辣么萌” 博客,请务必保留此出处http://momo462.blog.51cto.com/10138434/1813841
相关文章推荐
- 关于对象初始化内部顺序的个人见解
- JS面试题集锦
- 2016年3月iOS面试总结
- 剑指offer之面试题17 :合并两个排序的链表
- 面试题: 栈和队列的OC实现.
- php面试题
- 剑指offer之面试题19:二叉树的镜像
- 剑指offer之面试题18:树的子结构
- "享元模式"-之Java,Android面试必问设计模式(9/9)
- 集合的补充(Map)
- php中级面试题
- [置顶] 年薪百万的年轻人都是怎样生活的?——脸书程序员的故事
- 纪念一下参加的腾讯阿里实习面试
- java各类面试题集合
- 牛客网程序员面试金典:1.2——原串翻转(java实现)
- 需要仔细读的书 (July 8, 2016)
- JAVA基础面试题(经典)
- iOS面试题四
- Java Android程序员软件开发知识:枚举的介绍,以及代码的编写教程。
- iOS面试题总结整理(附答案)