神奇的魔方阵--(MagicSquare)(1)
本篇文章只对奇数阶以及偶数阶中阶数n = 4K的魔方阵进行讨论.下面就让我们进入正题:
1 :魔方阵的相关信息:(百度百科)
https://baike.baidu.com/item/%E9%AD%94%E6%96%B9%E9%98%B5/10973743?fr=aladdin
2 :奇数阶和偶数阶魔方阵的排列规律.(源自百度百科) (可跳至第三部分)
#include<assert.h>
#include<stdio.h>
void Magic_Square_1()
{
#define ROW 3
#define COL ROW // 等价于 #define COL 3
assert(ROW % 2 != 0);
if (ROW % 2 == 0)//ROW & ! == 1 判断是否为奇数 &(只有全为1,才为1)
{
return;
}
int preRow = 0; //记录上一个数的行坐标
int preCol = 0; //记录上一个数的列坐标
int ar[ROW][COL] = {};
ar[0][COL / 2] = 1; //先放1
preRow = 0;
preCol = COL / 2;
for (int i = 2; i <= ROW * COL; i++)//1已经放入所以从2开始进行
{
if (ar[(preRow - 1 + ROW) % ROW][(preCol + 1) % COL] == 0)
//判断上一个数的上一行下一列是否有值若没有则放入当前的i
{
preRow = (preRow - 1 + ROW) % ROW;
preCol = (preCol + 1) % COL;
}
else
{ // 若有则i放在上一个数的下一行.
preRow = (preRow + 1) % ROW;
}
ar[preRow][preCol] = i;
}
for (int i = 0; i < ROW; i++)//打印
{
for (int j = 0; j < COL; j++)
{
printf("%3d", ar[i][j]);
}
printf("\n");
}
#undef ROW //取消定义
#undef COL
}
int main()
{
Maagic_Square_1();
return 0;
}
运行结果:
3.2.2) : 将取出来的值按照从大到小的顺序(或从小到大的顺序)排好,从二维数组的[0][0]下标开始(从二维数组[ROW - 1][COL - 1]的位置开始) 依次填入到数组中空白的位置.
(重点)排列n= 4*k 阶的魔方阵的关键是取出各个四阶魔方阵的对角线的元素.我们可以发现:所有在对角线的元素的行列下标只差都满足一定的规律:
即 |row - col|(绝对值) % 4 == 0 (对应图中黄色部分)或者(row + col)%4 == 3(对应图中红色部分) .同时我们可以定义一个数组br[ROW*ROW/2],
在第一步填入数据时对其行列下标进行判断,若满足对角线元素下标的特点,直接将数值存放到br中,同时对二维数组相应的位置赋零值.
这样br 中的数就是从小到大排列的,只需要在第二步时从二维数组ar 的ar[ROW - 1][COL - 1]的位置开始,
依次将数组br中的值填入到数组中空白的位置.
代码如下:
#include<stdio.h>
#include<assert.h>
void Magic_Square_4K()
{
#define ROW 8
#define COL ROW
int ar[ROW][COL] = {};
int br[ROW*ROW/2] = {};//用来存储4阶方阵对角线元素.
int num = 1;//从1开始填入
int k = 0;//数组br下标.
for (int i = 0; i < ROW; i++)
{
for (int j = 0; j < COL; j++)
{
if((i-j)%4==3||(i-j)%4==0|| (j - i) % 4 == 3 || (j - i) % 4 == 0)
{//先控制对角线元素为零,并将应该填在对角线的这些数记录到br中.
br[k] = num;
k += 1;
ar[i][j] = 0;
}
else
{
ar[i][j] = num;
}
num++;
}
}
int tag = 0;
for (int i = ROW - 1; i >= 0; i--)//将br中的数按照顺序,从ar[ROW-1][COl-1]开始对ar中为零的元素赋值.
{
for (int j = COL - 1; j >= 0; j--)
{
if (ar[i][j] == 0)
{
ar[i][j] = br[tag];
tag += 1;
}
}
} for (int i = 0; i < ROW; i++)//打印
{
for (int j = 0; j < COL; j++)
{
printf("%4d", ar[i][j]);
}
printf("\n");
}
#undef ROW
#undef COL
}
int main()
{
Magic_Square_4K();
return 0;
}
运行结果:
未完待续...
神奇的魔方阵--(MagicSquare)(1)的更多相关文章
- 神奇的魔方阵--(MagicSquare)(2)
在上一篇博客中,我们讨论了阶数为奇数,以及阶数为(4K)的魔方阵的排列规则,以及代码实现(详见:https://www.cnblogs.com/1651472192-wz/p/14640903.htm ...
- 任意阶魔方阵(幻方)的算法及C语言实现
写于2012.10: 本来这是谭浩强那本<C程序设计(第四版)>的一道课后习题,刚开始做得时候去网上找最优的算法,结果发现奇数和双偶数(4的倍数)的情况下算法都比较简单,但是单偶数(2的倍 ...
- 魔方阵算法及C语言实现
1 魔方阵概念 填充的,每一行.每一列.对角线之和均相等的方阵,阶数n = 3,4,5….魔方阵也称为幻方阵. 例如三阶魔方阵为: 魔方阵有什么的规律呢? 魔方阵分为奇幻方和偶幻方.而偶幻方又分为是4 ...
- C语言——打印魔方阵(每一行,每一列,对角线之和相等)
<一>魔方阵说明: 魔方阵是一个N*N的矩阵: 该矩阵每一行,每一列,对角线之和都相等: <二>魔方阵示例: 三阶魔方阵: 8 1 6 3 5 7 4 9 ...
- 【2(2N+1)魔方阵 】
/* 2(2N+1)魔方阵 */ #include<stdio.h> #include<stdlib.h> #define N 6 #define SWAP(x, y) {in ...
- n阶魔方阵(奇数阵)的输出
需求 要求输出1~n²的自然数构成的魔方阵. STEP 1 什么是魔方阵? 魔方阵,古代又称“纵横图”,是指组成元素为自然数1.2…n2的平方的n×n的方阵,其中每个元素值都不相等,且每行.每列以及主 ...
- 算法:九宫格问题--奇数阶魔方(Magic-Square)
一.魔方介绍 魔方(这里是简称,也可以叫幻方.魔术矩阵,Magic Square)是 n×n 正方形网格(n 为每侧的单元数),里面每个单元格填充了不同的正整数 1, 2, 3, ... , n2,并 ...
- Octave入门
Octave/Matlab Tutorial Octave/Matlab Tutorial Basic Operations 你现在已经掌握不少机器学习知识了 在这段视频中 我将教你一种编程语言 Oc ...
- 吴恩达-coursera-机器学习-week2
四.多变量线性回归(Linear Regression with Multiple Variables) 4.1 多维特征 4.2 多变量梯度下降 4.3 梯度下降法实践1-特征缩放 4.4 梯度下降 ...
随机推荐
- JavaScript Weekly
JavaScript Weekly 技术订阅 https://javascriptweekly.com/issues/489 WebGL https://xem.github.io/articles/ ...
- iframe & sandbox & 微前端
iframe & sandbox & 微前端 沙箱,容器,隔离 sandbox demo svg progress bar https://stackoverflow.com/ques ...
- select notes mark
select notes mark mark-line https://time.geekbang.org/column/article/224545
- 高倍币VAST,如何破局NGK算力市场?
2020年,全球经济危机的爆发,无疑是给全球经济蒙上了一层阴影.而世界主要经济体也开启了无节制的放水,通过一轮又一轮的宽松货币政策,以刺激经济的发展.然而宽松的货币政策也加速了以美元为首的货币贬值,同 ...
- NGK 路演美国站,SPC空投与NGK项目安全
最近,NGK全球巡回路演在美国最大城市纽约市落下帷幕,本次路演有幸邀请了NGK方面代表迈尔逊,纽约当地区块链大咖维克多以及美国当地社群意见代表乔治等人. 路演一开始,美国当地路演师Viko首先致辞,V ...
- CAD颜色对照表
cad颜色代码与RGB参数对应表 1 255 0 02 255 255 03 0 255 04 0 255 2555 0 0 2556 255 0 2557 0 0 08 128 128 1289 1 ...
- Git 学习相关笔记
Git Bash 相关命令学 基础概念 参考: https://www.cnblogs.com/gaoht/p/9087070.html https://www.runoob.com/git/git- ...
- 从微信小程序到鸿蒙js开发【06】——swiper&animator&marquee
目录: 1.swiper轮播图 2.image-animator幻灯片 3.marquee跑马灯 4.nginx动静分离 1.swiper轮播图 微信小程序的swiper组件中只能放置swiper-i ...
- Byte Buddy学习笔记
本文转载自Byte Buddy学习笔记 简介 Byte Buddy是一个JVM的运行时代码生成器,你可以利用它创建任何类,且不像JDK动态代理那样强制实现一个接口.Byte Buddy还提供了简单的A ...
- vue版本一直是2.9.6版本,卸载也卸载不掉,更新也更新不了
原文链接:https://blog.csdn.net/zlzbt/article/details/110136755 主要是找到本地文件 E:\StudyFile\VueStudy λ where v ...