| 编程中国 | 业界新闻 | 技术文章 | 视频教程 | 下载频道 | 程序源码 | 个人空间 | 编程论坛
全能ASP/PHP/ASP.NET主机,支持月付专业 MSSQL 数据库空间,支持月付专业 MySQL 数据库空间,支持月付学习型 ASP/PHP/ASP.NET 主机 30元/年
高端软件开发 = 年薪十万不是梦赛孚耐:软件保护加密专家身份认证令牌USB KEY 
共有 565 人关注过本帖
标题:[求助]九宫格
收藏  订阅  推荐  打印 
xvholly
Rank: 1
等级:新手上路
帖子:14
积分:240
注册:2007-1-31
[求助]九宫格

朋友们给我讲讲怎样实现九宫格的算法?
九宫格:将1~9不重复的填入3X3的格子里,使横,竖,斜数字相加都相等.
谢谢诸位了!
搜索更多相关主题的帖子: 九宫  
2007-3-28 19:11
song4
Rank: 12Rank: 12Rank: 12
等级:贵宾
威望:38
帖子:1506
积分:15212
注册:2006-3-25

呵呵
我只知道
先确定那些组加一起相等
然后各族互相组合

我说自尊那 看起来或许可笑 但它至少支着我 试着不让我颠倒 活着 如果只是不甘寂静的喧嚣 那就咆哮吧 让每个人都听得到学习JAVA
2007-3-28 21:37
yuyunliuhen
Rank: 12Rank: 12Rank: 12
等级:贵宾
威望:20
帖子:1419
积分:14466
注册:2005-12-12

这个好象以前做过


Go confidently in the  directions of your dreams,live the life you have imagined!Just do it!
It is no use learning without thinking!
2007-3-28 22:18
xvholly
Rank: 1
等级:新手上路
帖子:14
积分:240
注册:2007-1-31

以下是引用song4在2007-3-28 21:37:05的发言:
呵呵
我只知道
先确定那些组加一起相等
然后各族互相组合

那是不是先要算出,加起来应该是多少? 是的话还是想不出怎样计算每组的和.


2007-3-31 14:15
western8
Rank: 1
等级:新手上路
帖子:5
积分:150
注册:2007-4-2

这是二维幻方游戏吧,有规律的。自己先找找,很简单的;
Hint:可以斜着填。
2007-4-2 00:56
wfpb
Rank: 12Rank: 12Rank: 12
等级:贵宾
威望:29
帖子:2188
积分:22230
注册:2006-4-2

斜着填好写一些...


[glow=255,red,2]wfpb的部落格[/glow] 学习成为生活的重要组成部分!
2007-4-2 15:05
xvholly
Rank: 1
等级:新手上路
帖子:14
积分:240
注册:2007-1-31
回复:(xvholly)[求助]九宫格

//终于知道算法了,还以为是要产生一组随机数来一个个的测试.

void array(int a[3][3])
{
int k = 1,
i = 0,
j = 1;
a[0][1] = k++;
while (k <= 9)
{
i--;
j++;

if (i < 0 && j > 2)
{
i += 2;
j --;
}

if (i < 0)
{
i = 2;
}
if (j > 2)
{
j = 0;
}

if (a[i][j] == 0)
{
a[i][j] = k++;
}
else
{
i += 2;
j--;
a[i][j] = k++;
}
}
}


2007-4-20 13:17
sunkaidong
Rank: 12Rank: 12Rank: 12
来自:南京师范大学
等级:版主
威望:4
帖子:4128
积分:44851
注册:2006-12-28

算法是不错,可以说一下数学上的依据吗?

学习需要安静。。海盗要重新来过。。
2007-4-20 13:41
sunkaidong
Rank: 12Rank: 12Rank: 12
来自:南京师范大学
等级:版主
威望:4
帖子:4128
积分:44851
注册:2006-12-28

#include "stdio.h"

void array(int a[3][3])
{
int k = 1,
i = 0,
j = 1;
a[0][1] = k++;
while (k <= 9)
{
i--;
j++;

if (i < 0 && j > 2)
{
i += 2;
j --;
}

if (i < 0)
{
i = 2;
}
if (j > 2)
{
j = 0;
}

if (a[i][j] == 0)
{
a[i][j] = k++;
}
else
{
i += 2;
j--;
a[i][j] = k++;
}
}
}
main()
{ int a[3][3]={0};
array(a);
for(int i=0;i<3;i++)
{
for( int j=0;j<3;j++)
{
printf(" %d ",a[i][j]);
}
printf("\n");
}
}

我把测试数据也给了,就是不知道为什么?再顶一下


学习需要安静。。海盗要重新来过。。
2007-4-20 13:42
风之语录
Rank: 2
等级:注册会员
帖子:62
积分:744
注册:2006-3-15

这算法不是古书里写的步法吗???

2007-4-20 14:25
关于我们 | 广告合作 | 编程中国 | 清除Cookies | Archiver | WAP | TOP

编程中国 版权所有,并保留所有权利。鲁ICP备08000592号
Powered by Discuz, Processed in 0.060498 second(s), 9 queries.
Copyright©2004-2008, BCCN.NET, All Rights Reserved