N(奇数)阶幻方解法 ...

        幻方也加魔方,通俗点就是N*N的方格中,填入1~n^2个数,使得横坚斜的和都相同。大家最熟悉的应该就是九宫格的3阶了。这儿我只和大家分享一下奇数阶的;因为奇数阶的就只有一个规律,偶数阶的稍微有点复杂(其实我只会4阶,还是从射雕英雄传里面学来的,在写这篇博客的时候我也特地去百度了一下,发现偶数阶的好像不同的阶数规律不一样,所以这儿 就只和大家说说偶数阶的了)。


3阶
816
357
492




5阶
17241815
23571416
46132022
101219213
11182529
代码:

<span style="color:#3366ff;">#include<iostream>
#include<iomanip>
using namespace std;
const int N = 9;//定义阶数,当前9阶;该算法只适合奇数阶幻方 
int main()
{</span>
<span style="color:#3366ff;">    if(N < 3 || N % 2 == 0)
    {
        cout << "此算法只适用于奇数阶幻方,且最小为3阶" << endl;
        exit(0);
    }
    int a[N+1][N+1] = {0};//为了方便理解,a[0][0]就没用 
    int row = 1, col = (N+1)/2;//第一行的最中间的坐标 
    a[row][col] = 1;//第一行的最中间为 1

    for(int i = 2; i <= N * N; i++)//从2开始填入 
    {
        if((i - 1) % N == 0)//如果遇到N的整数倍,则纵坐标不变,横坐标加1 
        {
            row++;
            a[row][col] = i;
            continue;
        }
        else if(row == 1)//如果当前在第一行,下一个数的横坐标为N 
        {
            row = N;
            col++;//纵坐标加1 
            a[row][col] = i;
            continue;
        }
        else if(col == N)//如果当前在第N列,下一个数在第一列 
        {
            col = 1;
            row--;//横坐标减1 
            a[row][col] = i;
            continue;
        }
        else//横坐标减1,纵坐标加1 ,即斜向上填入 
        {
            row--;
            col++;
            a[row][col] = i;
            continue;
        }
    }

    for(int i = 1; i <= N; i++)//输出 
    {
        for(int j = 1; j <= N; j++)
            cout << setw(2) << a[i][j] << " ";

        cout << endl;
    }
}</span>




转载于:https://www.cnblogs.com/tolic/p/7142286.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值