螺旋矩阵


给一个正整数n,输出一个n*n的螺旋矩阵
螺旋矩阵可以是逆时针也可以是顺时针,也可以是从里到外,也可以是从外到里

顺时针,从外到里:
螺旋矩阵

#include <iostream>
using namespace std;

const int _N = 100;
int matrix[_N][_N];

//思想:递归每一圈
/*
  1   2   3   4
  12  13 14   5
  11  16  15  6
  10   9  8   7 
*/
void setMatrix(int x, int y, int start, int n)
{
	int i;
	if(n <= 0)
		return;
	if(n == 1)
	{
		matrix[x][y] = start;
		return;
	}
	for(i = x; i < x + n - 1; i++)  //左边
		matrix[i][y] = start++;
	for(i = y; i < y + n - 1; i++) //下边
		matrix[n + x - 1][i] = start++; 
	for(i = x + n - 1; i > x; i--) //右边
		matrix[i][n + y - 1] = start++;
	for(i = y + n - 1; i > y; i--) //上边
		matrix[x][i] = start++;
	setMatrix(x + 1, y + 1, start, n - 2);

}
int main()
{
	int n, i, j;
	while(cin>>n)
	{
		setMatrix(0, 0, 1, n);
		for(i = 0; i < n; i++)
		{
			for(j = 0; j < n; j++)
			{
				printf("%4d", matrix[i][j]);
			}
			cout<<endl;
		}
	}
	return 0;
}

你可能感兴趣的:(矩阵)