1. 程式人生 > >編寫程式實現n階(n為奇數)魔方(C)

編寫程式實現n階(n為奇數)魔方(C)

#include <stdio.h>void Init (int square[][20],int n) {
int i,j;
for (i=1;i<=n;i++){
for (j=1;j<=n;j++)
square[i
-1][j-1]=0;
}
}
void put (int square[][20],int n)
{
int p,q,l,k,i;
p
=n/2;
q
=n-1;
for(i=1;i<=n*n;i++)
{
square[p][q]
=i;
l
=q;k=p;
p
++;q++;
if(p==n)
p
=p%n;
if(q==n)
q
=q%n;
if(square[p][q]!=0)
{
q
=l-1;
p
=k;
}
if(q==-1)
q
=n-1;
}
}
void show (int square[][20],int n) {
int i,j;
for (i=1;i<=n;i++) {
for (j=1;j<=n;j++)
printf(
"%4d",square[i-1][j-1]);
printf(
"");
}
}
int calculate (int square[][20],int n) {
int s,i;
s
=0;
for (i=1;i<=n;i++)
s
=s+square[0][i-1];
return s;
}

main () {
int square[20][20];
int n,sum;
do {
printf(
" 請輸入奇數 n: 
");
scanf(
"%d",&n);
while ((n%2==0)||(n<3)||(n>19)); 
Init(square,n);
put(square,n);
show(square,n);
sum
=calculate(square,n);
printf(
"共有%d個數. ",sum);
getch();
}

/*編寫程式實現n階(n為奇數)魔方。n為外部輸入引數,輸出結果按方陣排列。*/