纯手工制作魔方需要什么工具啊,自己打磨的,不要组装的

来源:百度知道 编辑: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列时换行
}<