leetcode-顺时针打印矩阵-50

题目要求
  输入一个矩阵,按照从外向里以顺时针的顺序依次打印出每一个数字。
思路
  模拟二维矩阵的边界,如果打印过,边界就对应缩小,直到将数组内的元素打印完。

代码实现

class Solution {
public:
	vector spiralOrder(vector>& matrix) {
		if (matrix.empty())
			return{};

		int b = matrix.size()-1;       //下边界
		int r = matrix[0].size()-1;    //右边界
		int t = 0;                   //上边界
		int l = 0;                   //左边界
		vector res;

		while (true)
		{
			//left->right
			for (int i = l; i <= r; i++)
				res.push_back(matrix[t][i]);
			if (++t > b)
				break;
			for (int i = t; i <= b; i++)
				res.push_back(matrix[i][r]);
			if (--r < l)
				break;
			for (int i = r; i >= l; i--)
				res.push_back(matrix[b][i]);
			if (--b < t)
				break;
			for (int i = b; i >= t; i--)
				res.push_back(matrix[i][l]);
			if (++l > r)
				break;
		}
		return res;
	}
};

你可能感兴趣的:(oj题)