剑指offer——顺时针打印矩阵

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

例如,如果输入如下4 X 4矩阵:

 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.

C++代码:

class Solution4 {
public:
	vector<int> printMatrix(vector<vector<int>> matrix) {
        vector<int> result;
		result.clear();
		int row = matrix.size();
		int collor = matrix[0].size();
		
		int circle = ((row < collor ? row : collor) - 1) / 2 + 1;
		for (int i = 0; i < circle; i++) {
			for (int j = i; j < collor - i; j++)
				result.push_back(matrix[i][j]);
			for (int k = i + 1; k < row - i; k++)
				result.push_back(matrix[k][collor - 1 - i]);
			for (int m = collor - i - 2; (m >= i) && (row - i - 1 != i); m--)
				result.push_back(matrix[row - i - 1][m]);
			for (int n = row - i - 2; (n > i) && (collor - i - 1 != i); n--)
				result.push_back(matrix[n][i]);
		}
		return result;
	}
};

 

全部评论

相关推荐

评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务