本文目录一览:
- 1、关于C语言编奇数阶魔方阵的问题
- 2、C语言问题:编写程序完成对n阶矩阵(n为奇数)的变换,将原矩阵左下角n/2阶子块中的数据与右上角n
- 3、c语言实现 3阶幻方
- 4、用c语言怎么打出奇数阶的魔方阵?
- 5、魔方阵的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...);
}