动态网站制作指南 [  QQ表情  ]
[ 投票调查 ]
[ 企业邮箱 ]
[ 网站空间 ]
网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
ASP源码 | .Net源码 | PHP源码 | JSP源码 | JAVA源码 | CGI源码 | VB源码 | C++源码 | Delphi源码 | PB源码 | VF源码 | 汇编 | 服务器
电脑书籍下载:程序设计书籍 | 数据库教程书籍 | 平面与多媒体书籍 | 网络通讯书籍 | 系统管理书籍 | 网络安全书籍 | 认证考试书籍
Firefox | IE | Maxthon | 迅雷 | 电驴 | BitComet | FlashGet | QQ | QQ空间 | Vista | 输入法 | Ghost | Word | Excel | wps | Powerpoint
asp | .net | php | jsp | Sql | c# | Ajax | xml | Dreamweaver | FrontPages | Javascript | css | photoshop | fireworks | Flash | Cad | Discuz!
当前位置 > 网站建设学院 > 网络编程 > C/C++教程
Tag:注入,存储过程,分页,安全,优化,xmlhttp,fso,jmail,application,session,防盗链,stream,无组件,组件,md5,乱码,缓存,加密,验证码,算法,cookies,ubb,正则表达式,水印,索引,日志,压缩,base64,url重写,上传,控件,Web.config,JDBC,函数,内存,PDF,迁移,结构,破解,编译,配置,进程,分词,IIS,Apache,Tomcat,phpmyadmin,Gzip,触发器,socket
网络编程:ASP教程,ASP.NET教程,PHP教程,JSP教程,C#教程,数据库,XML教程,Ajax,Java,Perl,Shell,VB教程,Delphi,C/C++教程,软件工程,J2EE/J2ME,移动开发
文章搜索服务
邮件订阅
输入你的邮件地址,
你将不会错过任何关于:
[ C/C++教程 ]的信息



本月文章推荐
.简单飘雪程序.
.GTK+ FAQ.
.Networks(网络).
.C/C++中的整型常识.
.数据结构算法集---C++语言实现.
.C++程序员必需的修养.
.C语言编程常见问题解答之常用函数.
.哪一个奴隶不会死.
.实现Cookie.
.C++ STL编程轻松入门.
.CRC-16/CRC-32 程序代码.
.C\C++建立IPC连接之后续操作.
.用BCB5的打包程序打包BCB6.
.Visual C++利用多线程模拟并行计.
.C++中的虚函数(virtual function).
.怎样用C语言编写一个DOS下的中断.
.为Windows窗口标题栏添加新按钮.
.VC++实现混合静态分裂视窗的方法.
.QQ用户小心了! C语言实现QQ密码大.
.伪随机数生成及在VC++中的实现.

容易理解魔方阵源程序

发表日期:2008-3-8 |


所谓魔方阵是指这样的的方阵: 它的每一行、每一列和对角线之和均相等。 输入n,要求打印由自然数1到n2的自然数构成的魔方阵(n为奇数)。 例如,当n=3时,魔方阵为: 8   1   6 3   5   7 4   9   2    此题要求输入一个数据n,然后打印出奇数阶魔方阵。要打印出奇数阶魔方阵,首先要明白奇数阶魔方阵的生成方法。其生成方法如下: (1) 第一个位置在第一行正中; (2) 新位置应当处于最近一个插入位置右上方,但如右上方位置已超出方阵上边界,则新位置取应选列的最下一个位置,如超出右边界则新位置取应选行的最左一个位置; (3) 若最近一个插入元素为N的整倍数,则选下面一行同列上的位置为新位置。    了解了其生成方法,就可以根据此方法来写出程序。首先设置int变量i,j,m,n。将从键盘输入的数据存入地址&n。然后再设置int数组a[MAX][MAX],由于数组在定义时,必须设置其宽度。所以在开始时定义MAX的大小,以后当出入的数字大于MAX时只需改动MAX即可。在此先设置为15。而根据生成方法可写出下列程度来实现对魔方阵的排列:   i=0,j=(n+1)/2-1;       /*代表第一行最中间的一列*/ while(m<=n*n)            /*一共n*n个数*/ {     a[i][j]=m; m++,i--,j++;      /*i--,j++;代表下一个数在原来那个数的右上方*/ if((m-1)%n==0&&m>=1)          /* ( 1 )  */ i=i+2,j=j-1;                   /*(2)*/
if(i<0) i=i+n;            /*超出上界则i+n*/ if(j>(n-1)) j=j-n;        /*超出右边界则j-n*/ }   注释(1)其根据为第三个要求。当m-1为5的整数倍时,其位置为上一个数位置的同一列下面一行,由于当m=1时(m-1)%n=0,但不用遵循其要求所有用 if( (m-1)%n==0&&m>=1)加以限制。 注释(2)由于在执行这一步之前经历了i--,j++。则要使之位置为原来的下方则i+2,j-1; 最后利用循环语句输出结果。 其程序为: #define MAX 15 #include <stdio.h> main() { int n; int m=1; int i,j; int a[MAX][MAX]; clrscr(); scanf("%d",&n); i=0,j=(n+1)/2-1; while(m<=n*n) {       a[i][j]=m; m++,i--,j++; if((m-1)%n==0&&m>1) i=i+2,j=j-1;
if(i<0) i=i+n; if(j>(n-1)) j=j-n; } for(i=0;i<n;i++)        for(j=0;j<n;j++)         { if(a[i][j]/10==0)         printf("%d   ",a[i][j]);    /*对程序无影响,只是使输出的数        else printf("%d  ",a[i][j]);           每一列对齐*/         if(j==(n-1)) printf(" ");}   }

上一篇:迷宫问题 人气:524
下一篇:More Effective C++之效率 人气:251
浏览全部C/C++的内容 Dreamweaver插件下载 常用网页广告代码全集
  最新网站源码 最新软件下载
2008-7-24 Sablog-X v2.0 预览版
2008-7-24 帝国备份王EmpireBak 2008 正式版
2008-7-24 网趣网上购物系统时尚版 v8.2
2008-7-24 纵横B2B电子商务系统XYECS!B2B v
2008-7-24 e路小说小偷 v1.2.0723
2008-7-24 凌风美女图片站程序 v2.2
2008-7-24 TOM15电影收索程序
2008-7-24 清风信息自动采集生成系统 v1.0
2008-7-24 QQ邮箱编辑器 v1.0 (小小菜刀ASP
2008-7-19 UltraEdit 简体中文增强版 14.10
2008-7-19 CentOS 5.2 i386 LiveCD
2008-7-19 Snapture多功能相机 v1.4
2008-7-19 iAcces中文输入法 v1.0Build016
2008-7-19 Cookbook烹饪秘籍 v2.5
2008-7-19 苹果专用DVD转换工具 v1.1.59汉化
2008-7-19 Modem修复软件ZiPhone修改版04.0
2008-7-19 AgileMessenger即时通讯工具美化
2008-7-19 Sketches画图软件 v0.7b6破解版


  发表评论
姓 名: 验证码:
内 容:
[ 汉字翻译拼音 ] [ 广告代码 ] [ 符号对照表 ] [ 进制转换 ] [ 经典小工具 ] [ 个税计算 ] [ 汉字简繁转换 ] [ 普通单位换算 ] [ 公制单位换算 ]
[ 生辰老黄历 ] [ 国内电话区号 ] [ 国家代码与域名缩写 ] [ 文字加密解密 ] [ 健康查询 ] [ 万年历 ] [ 手机号码查询 ] [ ip搜索 ] [ Google PR查询 ]
业务联系 | 广告刊登 | 频道合作 | 投稿荐稿 | 联系方式 | 加入收藏 | RSS订阅
Copyright © 2000-2008 www.knowsky.com All rights reserved | 网络实名:动态网站制作指南 | 沪ICP备05001343号
ホームページ制作 不動産検索システム 求人情報
防水工事·改修工事 フットサル大会 探偵