输入一个矩阵,按照从外向里以顺时针的顺序依次打印出每一个数字,例如,如果输入如下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.

思想:

1、输出第一行

2、将第一行删除

3、将删除第一行后的矩阵逆时针旋转90°。转1.

 

旋转矩阵相关函数:

vector<vector<int>> rotate(vector<vector<int>> roa) {
	if (!roa.size()) {//二维数组为0
		vector<vector<int>> t;
		return t;
	}
	//初始化大小非0二维数组,将M*N变为N*M大小,然后进行逆时针旋转90°
	vector<vector<int>> t(roa[0].size(), vector<int>(roa.size(),0));
	for (int i = roa[0].size() - 1; i >= 0; i--) {
		for (int j = 0; j < roa.size(); j++) {
			t[roa[0].size() - 1 - i][j] = roa[j][i];
		}
	}
	return t;
}

 

输出相关:

vector<int> printMatrix(vector<vector<int> > matrix) {
	vector<int> t;
	if (!matrix.size()) return  t;
	if (!matrix[0].size()) return t;
	while (matrix.size())
	{//返回顺序输出的数组
		for (int i = 0; i < matrix[0].size(); i++) {
			t.push_back(matrix[0][i]);
			}
		matrix.erase(matrix.begin());//将第0行数组清除
		matrix = rotate(matrix);//将二维数组逆时针旋转90°
	}
	
	return t;
}

main函数;

int main()
{
	vector<vector<int>> t,k;
	vector<int> ret;
	int a1[] = { 1, 2,  3,  4};
	int b1[] = { 5, 6,  7,  8};
	int c1[] = { 9, 10, 11, 12 };
	int d1[] = { 13,14, 15, 16 };
	vector<int> a(a1, a1+4), b(b1, b1+4), c(c1, c1 + 4), d(d1, d1 + 4);
	t.push_back(a);
	t.push_back(b);
	t.push_back(c);
	t.push_back(d);
	ret = printMatrix(t);
	for (auto &a : ret) {
		cout << a << ' ';
	}
	getchar();

	return 0;
}

结果: