用C语言完成奇数阶魔方阵

奇数阶魔方阵的构造

  1. 初始化:创建一个n×n的矩阵,所有元素初始化为0。
  2. 填充数字:从矩阵的右上角(第一行最后一列)开始,放置数字1。
  3. 移动规则:按照以下规则移动填充下一个数字:
    • 如果下一个位置在矩阵内且未被填充,则移动到该位置。
    • 如果下一个位置在矩阵外,则根据方向(上、右、下、左)循环回到矩阵的对应边界。
    • 如果下一个位置已被填充,则根据方向顺时针旋转90度(上变左,左变下,下变右,右变上),然后再次尝试放置数字。
  4. 重复:重复步骤3,直到所有位置都被填充

以一个3阶魔方阵为例子:详细写出大致思路:

具体代码 :

#include <stdio.h>
#include <strings.h> 

int main(void)
{
	int n;
	printf("Input a num:");
	scanf("%d",&n);

	int a[n][n];
	
	//printf("sizeof(a) = %ld\n",sizeof(a));
	bzero(a,sizeof(a));
	
	int i = 0;
	int j = 0;
	int k = 1;

	int x,y;
	 
	a[0][n/2] = 1; 
	
	i = 0;
	j = n/2;
	
	for (k = 2; k <= n*n; ++k)
	{
		x = i;
		y = j;
		++j;
		if (j > n-1)
		{
			j = 0;
		}
		--i;
		if (i < 0)
		{
           i = n-1;//向上走,遇到边界回到最后一行
		}

		if (a[i][j] != 0)
		{
			i = x;
			j = y;

			++i;

			if (i > n-1)
			{
				i = 0;
			}
		}

		a[i][j] = k;

	}

	for (i = 0; i < n; ++i)
	{
		for (j = 0; j < n; ++j)
		{
			printf("%d ",a[i][j]);
		}
		putchar('\n');
	}

	return 0;
}

  • 8
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值