// 181.c
#include<stdio.h>
void main()
{
int a[5][5],(*p)[5],*q,m=1;
for(p=a;p<a+5;p++)
{
if((p-a)%2==0)
{
q=*p;
while(q<*p+5)
{
*q++=m++;
}
}
else
{
q=*p+4;
while(q>=*p)
{
*q--=m++;
}
}
}
for(p=a;p<a+5;p++,printf("\n"))
for(q=*p;q<*p+5;q++)
printf("%3d",*q);
getch();
}
// 182.c
#include<stdio.h>
void main()
{
int a[5][5],(*p)[5],*q,m=1,flag=1;
q=*a;
while(m<=25)
{
if(flag==1)*q++=m;
else *q--=m;
if(m%5==0){
if(flag==1)p=q-1;
else p=q+1;
p++;
q=*p;
flag=-flag;}
m++;
}
for(p=a;p<a+5;p++,printf("\n"))
for(q=*p;q<*p+5;q++)
printf("%3d",*q);
getch();
}
// 183.c
#include<stdio.h>
void main()
{
int a[5][5]={1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25};
int (*p)[6];
p=a;
while(p<a+5)
{
printf("%3d",**p);
p++;
}
getch();
}
// 184.c
#include<stdio.h>
void main()
{
int a[5][5],m=1,i,j,k;
for(k=0;k<10;k++)
{
for(i=0;i<5;i++)
for(j=0;j<5;j++)
if(i+j==k)a[i][j]=m++;
}
for(i=0;i<5;i++,printf("\n"))
for(j=0;j<5;j++)
printf("%3d",a[i][j]);
getch();
}
// 185.c
#include<stdio.h>
#define M 10
void main()
{
int a[M][M],i,j,k,m=1;
for(k=0;k<2*M-1;k++)
for(i=0;i<M;i++)
for(j=0;j<M;j++)
if(i+j==k)
if(k%2==1)a[i][j]=m++;
else a[j][i]=m++;
for(i=0;i<M;i++,printf("\n"))
for(j=0;j<M;j++)
printf("%3d",a[i][j]);
getch();
}
// 186.c
#include<stdio.h>
#define M 5
void main()
{
int a[M][M]={0},i=0,j=M/2,m=1;
a[0][M/2]=m;
m++;
while(m<=M*M)
{
i--;j++;
if(i<0&&j==M||a[i][j]!=0&&i>=0&&j<M){i=i+2;j=j-1;}//对角线超范围,内部元素挡住了。
else if(i<0)i=M-1;//垂直方向超出范围。
else if(j==M)j=0;//水平方向超出范围.
a[i][j]=m++;
}
for(i=0;i<M;i++,printf("\n"))
for(j=0;j<M;j++)
printf("%3d",a[i][j]);
getch();
}
// 187.c
#include<stdio.h>
#define M 5
void fun(int (*a)[M],int m,int n)
{
int i=0,j=0;
if(n<0)return;
for(i=0;i<n;i++)a[i][0]=m++;
for(j=1;j<n;j++)a[n-1][j]=m++;
for(i=n-2;i>=0;i--)a[i][n-1]=m++;
for(j=n-2;j>=1;j--)a[0][j]=m++;
fun(*(a+1)+1,m,n-2);
}
void main()
{
int a[M][M],(*p)[M],*q;
fun(a,0,M);
for(p=a;p<a+M;p++,printf("\n"))
for(q=*p;q<*p+M;q++)
printf("%4d",*q);
getch();
}
// 188.c
#include<stdio.h>
#define M 8
void fun(int (*a)[M],int m,int n)
{
int (*p)[M],(*k)[M],*q;
if(n<1)return;
for(q=*a;q<*a+n;q++)*q=m++;
p=q-1;k=p;p++;
while(p<k+n){**p=m++;p++;}
for(q=*(p-1)-1;q>=*(a+n-1);q--)*q=m++;
for(p=a+n-2;p>*a;p--)**p=m++;
fun(*(a+1)+1,m,n-2);
}
void main()
{
int a[M][M],(*p)[M],*q;
fun(a,1,M);
for(p=a;p<a+M;p++,printf("\n"))
for(q=*p;q<*p+M;q++)
printf("%3d",*q);
getch();
}
// 189.c
#include<stdio.h>
#define M 5
void fun(int (*a)[M],int m,int n)
{
int (*p)[M],(*k)[M],*q;
if(n<1)return;
for(p=a;p<a+n;p++)**p=m++;
for(q=*(p-1)+1;q<*(p-1)+n;q++)*q=m++;
p=k=q-1;p--;
while(p>k-n){**p=m++;p--;}
for(q=*(p+1)-1;q>*a;q--)*q=m++;
fun(*(a+1)+1,m,n-2);
}
void main()
{
int a[M][M],(*p)[M],*q;
fun(a,1,M);
for(p=a;p<a+M;p++,printf("\n"))
for(q=*p;q<*p+M;q++)
printf("%3d",*q);
getch();
}
// 190.c
#include<stdio.h>
#define M 5
void main()
{
int a[M][M],i,j,k,m=1;
for(k=0;k<2*M-1;k++)
for(i=0;i<M;i++)
for(j=0;j<M;j++)
if(i+j==k)
if(k%2==1)a[M-i-1][M-j-1]=m++;
else a[M-j-1][M-i-1]=m++;
for(i=0;i<M;i++,printf("\n"))
for(j=0;j<M;j++)
printf("%3d",a[i][j]);
getch();
}