前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >C++经典算法题-4N魔方阵

C++经典算法题-4N魔方阵

作者头像
cwl_java
发布2020-02-13 23:16:52
3770
发布2020-02-13 23:16:52
举报
文章被收录于专栏:cwl_Javacwl_Java

50.Algorithm Gossip: 4N魔方阵

说明

与奇数魔术方阵 相同,在于求各行、各列与各对角线的和相等,而这次方阵的维度是4的倍数。

解法

先来看看4X4方阵的解法:

在这里插入图片描述
在这里插入图片描述

简单的说,就是一个从左上由1依序开始填,但遇对角线不填,另一个由左上由16开始填,但只填在对角线,再将两个合起来就是解答了;如果N大于2,则以 4X4为单位画对角线:

在这里插入图片描述
在这里插入图片描述

至于对角线的位置该如何判断,有两个公式,有兴趣的可以画图印证看看,如下所示: 左上至右下:

代码语言:javascript
复制
j % 4 == i % 4
右上至左下:(j % 4 + i % 4) == 1

代码示例

代码语言:javascript
复制
#include<stdio.h> 
#include<stdlib.h>
#define N 8

    int main(void) {
        int i, j;
        int square[ N + 1][N + 1] ={
            0
        } ;

        for (j = 1; j <= N; j++) {
            for (i = 1; i <= N; i++) {
                if (j % 4 == i % 4 || (j % 4 + i % 4) == 1) square[i][j] = (N + 1 - i) * N - j + 1;

                else

            }
        }


        square[i][j] = (i - 1) * N + j;


        for (i = 1; i <= N; i++) {
            for (j = 1; j <= N; j++)
                printf("%2d ", square[i][j]);
            printf("\n");
        }


        return 0;
    }
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2020-01-17 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 50.Algorithm Gossip: 4N魔方阵
    • 说明
      • 解法
        • 代码示例
        领券
        问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档