首页 > 学院 > 开发设计 > 正文

Spiral Matrix

2019-11-14 09:08:26
字体:
来源:转载
供稿:网友

Given a matrix of m x n elements (m rows, n columns), return all elements of the matrix in spiral order.

For example,Given the following matrix:

[ [ 1, 2, 3 ], [ 4, 5, 6 ], [ 7, 8, 9 ]]

You should return [1,2,3,6,9,8,7,4,5].

vector<int> fun(vector<vector<int> > &matrix){	vector<int> result;	int m = matrix.size();	int n = matrix[0].size();	int left = 0;	int right = n-1;	int top = 0;	int bottom = m-1;	while (left <= right && top <= bottom)	{		if (top <= bottom)		{			for (int i = left; i <= right; i++)			{				result.push_back(matrix[top][i]);			}			top++;		}				if (left <= right)		{			for (int i = top; i <= bottom; i++)			{				result.push_back(matrix[i][right]);			}			right--;		}		if (top <= bottom)		{			for (int i = right; i >= left; i--)			{				result.push_back(matrix[bottom][i]);			}			bottom--;		}		if (left <= right)		{			for (int i = bottom; i >= top; i--)			{				result.push_back(matrix[i][left]);			}			left++;		}	}	return result;}


发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表