您的位置:

c语言完成奇数阶幻阵,c语言幻方矩阵

本文目录一览:

关于C语言编奇数阶魔方阵的问题

改动处

L10:j=(n/2)+1; n的中间元素是(n/2)+1,但是在数组当中的位置应该是(n/2) //别忘了位置0存第一个

L18,L20 不等号这里不能取等

L32: 输出格式改了一下,为了好看而已

改后程序

#include"stdio.h"

void main()

{

int a[15][15]={0};

int n,i,j,k,p,q;

printf("请输入魔方阵的阶(仅限奇数阶)\n");

scanf("%d",n);

i=0;

j=(n/2);

a[i][j]=1;

for(k=2;k=n*n;k++)

{

p=i;

q=j;

i--;

j++;

if(i0)

i=n-1;

if(jn-1)

j=0;

if(a[i][j]!=0)

{

i=p+1;

j=q;

}

a[i][j]=k;

}

for(i=0;in;i++)

{

for(j=0;jn;j++)

printf(" %3d ",a[i][j]);

printf("\n");

}

}

C语言问题:编写程序完成对n阶矩阵(n为奇数)的变换,将原矩阵左下角n/2阶子块中的数据与右上角n

#includestdio.h

int main(void)

{

    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 i,j,n;

    for(i = 0; i  5; i++)

    {

        for(j = 0; j = i; j++)

        {

            n = a[i][j];

            a[i][j] = a[j][i];

            a[j][i] = n;

        }

    }

    for(i = 0; i  5; i++)

    {

        for(j = 0; j 5; j++)

        {

            printf("%d ", a[i][j]);

        }

        printf("\n");

    }

    return 0;

}

c语言实现 3阶幻方

#includestdio.h

int main()

{

int i,j,i1,j1,x,a[100][100];

for(i=1;i=3;i++)

{

for(j=1;j=3;j++)

a[i][j] = 0;

}

i=1;

j = (int)((3+1)/2);

x=1;

while(x=3*3)

{

a[i][j] = x;

x++;

i1=i;

j1=j;

i--;

j--;

if(i==0)

i=3;

if(j==0)

j=3;

if(a[i][j] != 0)

{

i = i1+1;

j = j1;

}

}

for(i=1;i=3;i++)

{

for(j=1;j=3;j++)

printf("%3d",a[i][j]);

printf("\n");

}

return 1;

}

用c语言怎么打出奇数阶的魔方阵?

#includestdio.h

#define N 5

void main()

{

int s[N][N],a,b,i;

for(a=0,b=(N/2),i=2,s[a][b]=1;i=N*N;i++)

{

if(s[a][b]%N==0)

a++;

else

{

if(a-10) a=N-1;

else a--;

if(b+1==N) b=0;

else b++;

}

s[a][b]=i;

}

for(a=0;aN;a++)

{for(b=0;bN;b++)br printf("%-4d",s[a][b]);br printf("\n");}

}

魔方阵的C语言

代码一:

#include stdio.h

#define N 16 //这里可以修改N的值,并且N只能为偶数

int main()

{

int a[N][N]={0},i,j,k,p,m,n;

p=1;

while(p==1)

{

printf(Enter n(1~%d): ,N-1);/*可以输入小于等于N-1的奇数*/

scanf(%d,n);

if((n!=0)(nN)(n%2!=0)) p=0;

}

i=n+1;

j=n/2+1; /*建立魔方阵*/

a[1][j]=1;

for(k=2;k=n*n;k++)

{

i=i-1;

j=j+1;

if((i1)(jn))

{

i=i+2;j=j-1;

}

else

{

if(i1) i=n;

if(jn) j=1;

}

if(a[i][j]==0) a[i][j]=k;

else

{

i=i+2;

j=j-1;

a[i][j]=k;

}

}

for(i=1;i=n;i++)/*输出魔方阵*/

{

for(j=1;j=n;j++)

printf(%4d,a[i][j]);

printf(\n);

}

}

代码二:(相对于代码一条理更清晰,更简单、更容易理解)

将1~n的平方这几个数构成一个n阶魔方阵。

算法:

依以下法则,你可以很快的写出奇数阶幻方!当然,这种写法只是其中一个答案,而不是唯一答案。

1)将1填入第一行中间;

2)将每个数填在前一个数的右上方。

3)若该位置超出最上行,则改填在最下行的对应位置;

4)若该位置超出最右列,则该填在最左列的对应行位置;

5)若某元素填在第一行最右列,下一个数填在该数同列的下一行;

6)若某数已填好,但其右上角已填了其他数据,则下一个数填在该数同列的下一行位置。

#includestdio.h

void main()

{

int a[15][15]={0},i,j,m,n,temp,M;

printf(请输入一个3~15的奇数:\n);

scanf(%d,M);

i=0;

j=M/2;

a[i][j]=1;

for(temp=2;temp=M*M;temp++)

{

m=i;

n=j;

i--;

j++;

if(i0)

i=M-1;

if(jM-1)

j=0;

if(a[i][j]!=0)

{

i=m+1,j=n;

a[i][j]=temp;

continue;

}

a[i][j]=temp;

}

printf(%d×%d魔方阵:\n,M,M);

for(i=0;iM;i++)

{

for(j=0;jM;j++)

printf(%4d,a[i][j]);

printf(\n);

}

}

//(求4的倍数阶幻方)

void main()

{

int i,j,x,y,n,t,k=1;

int a[100][100];

printf(请输入魔方阵的阶数n \n);

scanf(%d,n);

printf(输出为:\n);

if(n%4==0)

{

for(i=0;in;i++)

for(j=0;jn;j++)

{

a[i][j]=k;

k++;

}

x=n-1;

for(j=0;jn/2;j++,x--)

{

for(i=0;in;i++)

if(i%4!=j%4(i+j)%4!=3)

{

t=a[i][j];

a[i][j]=a[i][x];

a[i][x]=t;

}

}

x=n-1;

for(i=0;in/2;i++,x--)

{

for(j=0;jn;j++)

if(i%4!=j%4(i+j)%4!=3)

{

t=a[i][j];

a[i][j]=a[x][j];

a[x][j]=t;

}

}

for(i=0;in;i++)

{

for(j=0;jn;j++)

printf(%-4d,a[i][j]);

printf(\n);

}

}

else printf(输入错误\n);

system(pause...);

}