玩转矩阵
简介:输入一个整数n,写一个n*n的矩阵,输出矩阵的环形矩阵,顺时针矩阵,逆时针矩阵。
输入:n;
输出:三个矩阵;
样例输入;4
样例输出;
环形矩阵:
1 2 3 4
12 13 14 5
11 16 15 6
10 9 8 7
顺时针90:
10 11 12 1
9 16 13 2
8 15 14 3
7 6 5 4
逆时针90;
4 5 6 7
3 14 15 8
2 13 16 9
1 12 11 10
代码:
#include<stdio.h>
int main()
{
int i,j,k,m,t,n,s,a[20][20]={0},b;
i=j=s=1;t=-1;k=0;b=0;
scanf("%d",&n);
m=n;b=n*n;
printf(“环形矩阵:\n “);
for(;s<=b;)
{
for(;j<=n;j++)
a[i][j]=s++;
i++;j–;
for(;i<=n;i++)
a[i][j]=s++;
j–;i–;
if(t>n)
k++;
for(;j>k;j–)
a[i][j]=s++;
i–;j++;
for(;a[i][j]==0;i–)
a[i][j]=s++;
t=n;
n=n-1;j++;i++;
}
for(i=1;i<=m;i++)
{
for(j=1;j<=m;j++)
printf(”%d “,a[i][j]);
printf(”\n”);
}
printf("\n");
printf(“顺时针旋转90:\n”);
for(j=1;j<=m;j++)
{
for(i=m;i>0;i–)
printf("%d “,a[i][j]);
printf(”\n");
}
printf("\n");
printf(“逆时针旋转90:\n”);
for(j=m;j>0;j–)
{
for(i=1;i<=m;i++)
printf("%d “,a[i][j]);
printf(”\n");
}
return 0;
}