由一道数学题的联想
然后根据网上的做法瞎jb乱打了一下,居然对了
代码精心附上了注释,有兴趣的童鞋可以看一看。。
不说了,上代码!(自认为结构很清晰易懂)

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
#include <cstdlib>
#include <cmath>
#include <cstdio>
#define MAXN 10000
using namespace std; int matrix[MAXN][MAXN] = { 0 }; void (int n)
{
int x = 0, y, mun = 1;
y = n / 2;
while (mun <= n * n)
{
matrix[x][y] = mun; //通过x0、y0检测右上的是否已经填入数字
int x0 = x;
int y0 = y;
x0--;
y0++;
//超界处理
if (x0 < 0)
x0 += n;
if (y0 == n)
y0 = n - y0;
if (!matrix[x0][y0])
{
x = x0;
y = y0;
}
else
{
//若有数字填入之前数字的下方
x++;
if (x == n) x = 0;
}
mun++;
}
} //生成双偶幻方
void CreateDoubleEvenMagicSqure(int n)
{
int num = 1;
//从1到n的平方依次赋值
for (int i = 0; i<n; i++)
for (int j = 0; j<n; j++)
matrix[i][j] = num++; //小正方形的对角线上的数字取其补数
for (int i = 0; i < n; i++)
for (int j = 0; j < n; j++)
{
if (i % 4 == 0 && 大专栏  C++求解N阶幻方an class="built_in">abs(i - j) % 4 == 0)
for (int k = 0; k<4; k++)
matrix[i + k][j + k] = abs(n * n + 1 - matrix[i + k][j + k]);
else if (i % 4 == 3 && (i + j) % 4 == 3)
for (int k = 0; k<4; k++)
matrix[i - k][j + k] = abs(n * n + 1 - matrix[i - k][j + k]); }
} //生成单偶幻方
void CreateSingleEvenMagicSqure(int n)
{
int k = n / 2;
CreateOddMagicSquare(k);
//赋初值,左上最小,右下其次,右上再次,左下最大
for (int i = 0; i < k; i++)
for (int j = 0; j < k; j++)
{
matrix[i + k][j + k] = matrix[i][j] + k * k;
matrix[i][j + k] = matrix[i][j] + k * k * 2;
matrix[i + k][j] = matrix[i][j] + k * k * 3;
}
//公式 n=4m+2
int m = (n - 2) / 4;
//交换x方向正中行的从左至右m-1个
for (int i = 0; i<m - 1; i++)
{
int buf = matrix[k / 2][i];
matrix[k / 2][i] = matrix[k / 2 + k][i];
matrix[k / 2 + k][i] = buf;
}
int buf = matrix[k / 2][k / 2];
//以及正中间的数
matrix[k / 2][k / 2] = matrix[k / 2 + k][k / 2];
matrix[k / 2 + k][k / 2] = buf; //交换除x正中间行的其他行对应数字m个
for (register int i = 0; i<k; i++)
for (register int j = 0; j<k / 2; j++)
{
if (i != k / 2)
{
int buf = matrix[i][j];
matrix[i][j] = matrix[i + k][j];
matrix[i + k][j] = buf;
}
} //交换最右边m-1个数字
for (register int i = 0; i < k; i++)
for (register int j = n - 1; j > n - 1 - (m - 1); j--)
swap(matrix[i][j], matrix[i + k][j]); }
bool Check(int n)
{
int sum = (n*(n*n + 1)) / 2;
int SumA = 0, SumB = 0; for (int i = 0; i < n; i++)
{
for (int j = 0; j < n; j++)
SumA += matrix[i][j];
if (SumA != sum)
return false;
SumA = 0;
} for (int i = 0; i < n; i++)
{
for (int j = 0; j < n; j++)
SumA += matrix[j][i];
if (SumA != sum)
return false;
SumA = 0;
} for (int i = 0; i<n; i++)
{
SumA += matrix[i][i];
SumB += matrix[i][n - i - 1];
}
if (SumA != sum || SumB != sum)
return false; return true; } int main()
{
int n;
cin >> n;
if (n % 2 != 0)
CreateOddMagicSquare(n);
else if (n % 4 == 0)
CreateDoubleEvenMagicSqure(n);
else if (n % 2 == 0)
CreateSingleEvenMagicSqure(n); for (int i = 0; i<n; i++)
{
for (int j = 0; j<n; j++)
cout << matrix[i][j] << "t";
cout << endl;
} if (!Check(n))
cout << "Failed to generate!" << endl;
getchar(), getchar();
return 0;
}

C++求解N阶幻方的更多相关文章

  1. 任意阶幻方(魔方矩阵)C语言实现

    魔方又称幻方.纵横图.九宫图,最早记录于我国古代的洛书.据说夏禹治水时,河南洛阳附近的大河里浮出了一只乌龟,背上有一个很奇怪的图形,古人认为是一种祥瑞,预示着洪水将被夏禹王彻底制服.后人称之为&quo ...

  2. Java 实现任意N阶幻方的构造

    一.关于单偶数阶幻方和双偶数阶幻方 (一)单偶数阶幻方(即当n=4k+2时) 任何4k+2 阶幻方都可由2k+1阶幻方与2×2方块复合而成,6是此类型的最小阶. 以6阶为例,可由3阶幻方与由0,1,2 ...

  3. Java 实现奇数阶幻方的构造

    一.设计的流程图如下所示 二.Java 语言的代码实现 package MagicSquare; //奇数幻方的实现 public class Magic_Odd { //n 为幻方的阶数 publi ...

  4. hdu1998 bjfu1272奇数阶幻方构造

    这题就是一个sb题,本来很水,硬是说得很含混.奇数阶幻方构造其实有好多方法,这题既不special judge,也不说清楚,以为这样能把水题变成难题似的,简直想骂出题人. /* * Author : ...

  5. Codeforces 710C. Magic Odd Square n阶幻方

    C. Magic Odd Square time limit per test:1 second memory limit per test:256 megabytes input:standard ...

  6. n阶幻方

    前序 最近在学习一些经典的算法,搞得头昏脑涨,就想换换脑子.在家里的旧书堆里面乱翻,无意中将一本具有十多年历史的小学数学奥林匹克竞赛的书发掘了出来,能放到现在挺不容易的,就拿起来随便翻翻.看了看目录, ...

  7. codeforces 710C Magic Odd Square(构造或者n阶幻方)

    Find an n × n matrix with different numbers from 1 to n2, so the sum in each row, column and both ma ...

  8. n阶幻方问题

    转载自:http://blog.csdn.net/fengchaokobe/article/details/7437767 目录        第一节 n阶幻方问题       第二节 由n阶幻方引发 ...

  9. ch2_8_1求解n阶螺旋矩阵问题

    思路:循环输出,注意边界控制 import java.util.Scanner; public class ch2_8_1求解n阶螺旋矩阵问题 { public static void main(St ...

随机推荐

  1. 深入理解spring中的AOP原理 —— 实现MethodInterceptor接口,自已动手写一个AOP

      1.前言 AOP是面向切面编程,即“Aspect Oriented Programming”的缩写.面对切面,就是面向我们的关注面,不能让非关注面影响到我们的关注面.而现实中非关切面又必不可少,例 ...

  2. 单个body|简单解释|复杂解释|反面解释

    单个body有三种方法简单解释.复杂解释和反面解释 ========================================================================== ...

  3. java中常见的json解析方法、库以及性能对比

    常见的json解析有原生的JSONObject和JSONArray方法,谷歌的GSON库,阿里的fastjson,还有jackson,json-lib. Gson(项目地址:https://githu ...

  4. 多标签图像分类任务的评价方法-mAP

    http://blog.sina.com.cn/s/blog_9db078090102whzw.html 多标签图像分类(Multi-label Image Classification)任务中图片的 ...

  5. jedis异常Broken pipe (Write failed)

    异常:java.net.SocketException: Broken pipe (Write failed); nested exception is redis.clients.jedis.exc ...

  6. Oscar的拓扑笔记本

    目录 Euler characteristic Euler定理 引入:绝对值 度量空间 Example: 开集,闭集 Topological space 什么是拓扑 拓扑空间 例子: Exercise ...

  7. [JSOI2019]神经网络(树形DP+容斥+生成函数)

    首先可以把题目转化一下:把树拆成若干条链,每条链的颜色为其所在的树的颜色,然后排放所有的链成环,求使得相邻位置颜色不同的排列方案数. 然后本题分为两个部分:将一棵树分为1~n条不相交的链的方案数:将这 ...

  8. 用bosybox制作文件系统

    在orangepi_sdk/source/busybox-1.25.0目录里有源码. ). 先清除编译出来的文件及配置文件 make distclean ). 配置busybox make menuc ...

  9. Mysql计算时间最近多久

    -- DATE_SUB(CURDATE(), INTERVAL 3 MONTH)计算结果为当前时间的前推三个月,time字段可为时间型字符串 select * form t_user where ti ...

  10. PHP验证电子邮件-密码保护和随机密码

    验证邮箱: function isValidEmail($email){ return eregi("^[_a-z0-9-]+(\.[_a-z0-9-]+)*@[a-z0-9-]+(\.[a ...