| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 844 人关注过本帖
标题:一个二维数组的问题(愿你能帮助我)
只看楼主 加入收藏
binghe517
Rank: 1
等 级:新手上路
帖 子:15
专家分:0
注 册:2004-7-9
收藏
 问题点数:0 回复次数:4 
一个二维数组的问题(愿你能帮助我)
一个二维数组的问题(愿你能帮助我)

本人近来遇到一问题,经过我的思索,我解出了这道题,但我中觉得有些遗憾,那就是我编写的程序很繁琐,望提出你宝贵的意见,指导我这个初学者。并愿你我成为不曾相识的朋友!!

例子:打印“魔方阵”。所谓的魔方阵是指住的方阵,它的每一行,每一列和对角线之和均相等。例如,三阶魔方阵为:

8 1 6

3 5 7

4 9 2

要求打印出由一到n^2的自然数构成的魔方阵。

搜索更多相关主题的帖子: border 对角线 朋友 
2004-07-20 18:44
乌鸦丘比特
Rank: 1
等 级:新手上路
威 望:2
帖 子:625
专家分:0
注 册:2004-7-19
收藏
得分:0 

魔方阵的n=奇数情况是有好算法的。

在第一行中间填1,在它的右上填上2,在2的右上填3,以此类推,右上如果上面没有格子就转到最下面,如果右边没格子了

转到最左边(像一些经典的小游戏一样,向最上面走,你会在最下面出现)。如果该数右上已经有数字,填在该数的下方。一直填,直到填满为止。


我喜欢创造,一只扑腾着翅膀向天空飞翔的乌鸦
2004-07-20 19:51
神vLinux飘飘
Rank: 13Rank: 13Rank: 13Rank: 13
来 自:浙江杭州
等 级:贵宾
威 望:91
帖 子:6140
专家分:217
注 册:2004-7-17
收藏
得分:0 

这个不是问过了吗?~可以自己看看我写的代码

http://bbs.bc-cn.net/bbs/dispbbs.asp?boardID=44&ID=3401&page=1


淘宝杜琨
2004-07-20 19:55
baidao
Rank: 1
等 级:新手上路
帖 子:12
专家分:0
注 册:2004-6-30
收藏
得分:0 

这是我以前写的写的不太好请各位高手指点一 二 啊~~~~~

# include<stdio.h> main() { int a[16][16],n,i,j,k; scanf("%d",&n); for(i=1;i<=n;i++) for(j=1;j<=n;j++) a[i][j]=0; j=n/2+1; a[1][j]=1; for(k=2;k<=n*n;k++) { i=i-1;j=j+1; if(i<1&&j>n) { i=i+2;j=j-1;} else { if(i<1) i=n; if(j>n) j=1; } if(a[i][j]==0) a[i][j]=k; else { i=i+2;j=j-1;a[i][j]=k;} } for(i=1;i<=n;i++) { for(j=1;j<=n;j++) printf("%5d",a[i][j]); printf("\n"); } }


2004-07-20 20:08
binghe517
Rank: 1
等 级:新手上路
帖 子:15
专家分:0
注 册:2004-7-9
收藏
得分:0 
呵呵...

多谢各位的帮忙。

我在这里对大家说声谢谢!!!

希望以后还能指教我。

2004-07-31 18:05
快速回复:一个二维数组的问题(愿你能帮助我)
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.035703 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved