- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
N阶魔阵问题
2011年6月14日
数据结构课程设计
一、实验题目
给定一奇数n,构造一个n阶魔阵。n阶魔阵是一个n阶方阵,其元素由自然数1,2,3,…,n2组成。魔阵的每行元素之和,每列元素之和以及主、副对角线之和均相等。既对于给定的奇数n以及i=1,2,3,…,n。魔阵a满足以上条件。
要求:要求输出结果的格式要具有n阶方阵的形式。
提示:依次将自然数填入方阵中,共填n轮,每轮填n次。第一轮的第一次,将1填入方阵的中间一行的最后一列位置。设前一次填入的位置是aij。
每轮中第2至第n次将数填入ai+1,j+1,若遇到下列情况之一,则填写位置按以下规则调整:
①. aij是最后一列(即j=n)位置,则将下一个数填入ai+1,1;
②. aij是最后一行(即i=n)位置,则将下一个数填入a1,j+1;
(2) 新一轮的第一次填入a1,j-1.
二、实验目的
了解并掌握数据结构与算法的设计方法,具备初步的独立分析和设计能力;
初步掌握软件开发过程的问题分析、系统设计、程序编码、测试等基本方法和技能;
提高综合运用所学的理论知识和方法独立分析和解决问题的能力;
训练用系统的观点和软件开发一般规范进行软件开发,培养软件工作者所应具备的科学的工作方法和作风;
输出一个奇数N阶的具有矩阵形式魔阵。
三、实验内容
(一)需求分析
1. 定义一个整形变量order存放魔术矩阵的阶数
order为一整形变量,是通过键盘来进行输入的阶数,也是进行分析的条件,可通过形参的值传递到子函数中,再对魔术矩阵按照进行排列,要求如下:
n阶魔方矩阵是将自然数放置在一个的方阵中,同时要保证该矩阵每行﹑每列及两条主对角线(即主对角线和副对角线)上的数值之和相等的要求。这似乎是一件比较复杂的事情,其实,求解“魔方矩阵”(奇数阶)有一个很巧
妙的算法,这个算法的 描述如下:
(1)初始化“魔方矩阵”,即将所有元素置为0;
(2)首先将1放置在第1行的中间位置。
(3)将之间的整数按照下列规则依次放置在方阵中:
如果上一个数值所放置的位置的右上方为空(该位置还没有放置数值),则当前数值被放置在一个数值的右上方;否则被放置在上一个数的正下方。
很显然,“魔方矩阵”中的数据具有明显的二维排列关系,因此应该选用二维数组表示待求解的“魔方矩阵”。
(4)对于给定的奇数n以及,魔方矩阵满足的条件用数学表示如下:
定义为整型,将其返回,在主程序中打印出来。
(5)显示“魔方矩阵”;
2. 算法流程图
在主函数中定义order为整型,由键盘输入;
定义整型变量row,column来描述数组插入的位置;
(二) 概要设计
(1)定义的存储结构描述:
首先在函数首部定义:#define MAXSIZE 31
定义一个数组matrix[MAXSIZE][MAXSIZE];对n阶魔术矩阵进行存储;其中matrix[MAXSIZE][MAXSIZE]的参数类型为整型,此数组的最大值定义为31,如果超出则会发生错误,
定义一个整型变量order,将order 的值传到形参,在算法中对order阶的矩阵排列,使其满足下列条件:
因此称这样的矩阵为魔术矩阵;在算法程序中定义matrix[MAXSIZE][MAXSIZE];其中定义为整型,将其返回,在主程序中打印出来。
算法分析:
①.下面一段程序是用来限制输入的魔方矩阵的阶数所用:
if (orderMAXSIZE)
{printf(\n取值超出范围:\n);
printf(\n*******************************);
}
else if (order%2==0)
{printf(\n输入有错误,请重新输入:\n);
printf(\n*******************************);
}
②.下面一段程序是求解N阶魔方矩阵最关键的部分:首先将1放置在第1行的中间位置。将之间的整数按照下列规则依次放置在方阵中:
如果上一个数值所放置的位置的右上方为空(该位置还没有放置数值),则当前数值被放置在一个数值的右上方;否则被放置在上一个数的正下方。
row=0; /* start of from the middle */
column=order/2; /* of the first row. */
for (count=1;count=order*order; count++)
{
matrix[row][column] = count; /* put next # */
if (count % order == 0) /* move down ? */
row++; /* YES, move down one row
您可能关注的文档
- 毕业论文--论钢琴基础教育在儿童音乐教育中的地位和作用.doc
- 毕业论文--试析中德翻译中的翻译不足和翻译冗余现象.doc
- 德语歌剧与中国京剧的差异-德语论文.doc
- 德语论文_亚洲学生同质性Beratung_von_ostasiatischen_Studierenden.docx
- 德语论文--德国二战后对犹太人的补偿.doc
- 德语专业论文--由德国法制先进性浅析中国法律.doc
- 高级审计理论与实务课程论文--论如何完善上市公司信息披露制度.doc
- 过程原理课程设计任务书--吸收氨过程填料塔的设计.doc
- 护理毕业论文范文--对病患及家属的心理护理.doc
- 化工原理课程设计--清水吸收填料吸收塔设计.doc
最近下载
- 人教版二学年上册生字田字格版.doc VIP
- 上教版(试用本)六年级劳动技术全一册电子课本教材.pdf VIP
- 2024年食品安全监管人员专业知识考核试题A卷 附解析.docx VIP
- 2025贵州仟山农林开发(集团)有限公司招聘14人笔试备考试题及答案解析.docx VIP
- 昆明市初三化学初三化学上册期末试卷及答案.doc VIP
- 2025年高校辅导员专业能力综合测试卷.docx VIP
- 2022年四川定向公共基础知识真题(含答案).pdf VIP
- 人教版数学三年级上册第五单元倍的认识单元测试卷(i)卷.doc VIP
- 第4课 社会主义基本经济制度.pptx VIP
- 人教版数学三年级上册第五单元 倍的认识 单元测试卷a卷.doc VIP
原创力文档


文档评论(0)