纯手工制作魔方需要什么工具啊,自己打磨的,不要组装的
来源:百度知道 编辑:UC知道 时间:2024/05/22 19:31:49
程序代码:
//其生成方法:
//(1) 第一个位置在第一行正中;
//(2) 新位置应当处于最近一个插入位置右上方,但如右上方位置已超出方阵上边界,则新位置取应选列的最下一个位置,如超出右边界则新位置取应选行的最左一个位置;
//(3) 若最近一个插入元素为N的整倍数,则选下面一行同列上的位置为新位置。
#define MAX 15
#include <stdio.h>
main()
{
int n;
int m=1;
int i,j;
int a[MAX][MAX];
scanf("%d",&n);//n必须为奇数
i=0,j=(n+1)/2-1;//第一个位置在第一行正中
while(m<=n*n)
{
a[i][j]=m;
m++,i--,j++;
if((m-1)%n==0&&m>1)
i=i+2,j=j-1;//当m-1能整除n时选择同列的下行来存储
if(i<0) i=i+n;//超出上界则i+n
if(j>(n-1)) j=j-n;//超出右边界则j-n
}
for(i=0;i<n;i++)//输出
for(j=0;j<n;j++)
{
if(a[i][j]/10==0) printf("%d ",a[i][j]);
else printf("%d ",a[i][j]); //对齐
if(j==(n-1)) printf("\n");//超出n列时换行
}<