Description
回形取数就是沿矩阵的边取数,若当前方向上无数可取或已经取过,则左转90度。一开始位于矩阵左上角,方向向下。
Input
输入第一行是两个不超过200的正整数m, n,表示矩阵的行和列。接下来m行每行n个整数,表示这个矩阵。
Output
输出只有一行,共m*n个数,为输入矩阵回形取数得到的结果。数之间用一个空格分隔,行末不要有多余的空格。
Sample Input
3 3
1 2 3
4 5 6
7 8 9
Sample Output
1 4 7 8 9 6 3 2 5
代码
#include<bits/stdc++>
using namespace std;
int main()
{
int m,n;
int i,j,num;
int a[205][205];
while(~scanf("%d%d",&m,&n))
{
memset(a,-1,sizeof(a));
for(i=0;i<m;i++)
{
for(j=0;j<n;j++)
{
scanf("%d",&a[i][j]);
}
}
int tot=0;
i=-1; j=0;
while(tot<m*n)
{
while(i+1<m&&a[i+1][j]!=-1)
{
if(i==-1&&j==0)
printf("%d",a[++i][j]);
else
printf(" %d",a[++i][j]);
a[i][j]=-1;
++tot;
}
while(j+1<n&&a[i][j+1]!=-1)
{
printf(" %d",a[i][++j]);
a[i][j]=-1;
++tot;
}
while(i-1>=0&&a[i-1][j]!=-1)
{
printf(" %d",a[--i][j]);
a[i][j]=-1;
++tot;
}
while(j-1>=0&&a[i][j-1]!=-1)
{
printf(" %d",a[i][--j]);
a[i][j]=-1;
++tot;
}
}
printf("\n");
}
return 0;
}