| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1656 人关注过本帖, 1 人收藏
标题:[分享]经典问题——八皇后问题
只看楼主 加入收藏
shensheng4
Rank: 1
等 级:新手上路
帖 子:80
专家分:0
注 册:2005-8-7
收藏(1)
 问题点数:0 回复次数:4 
[分享]经典问题——八皇后问题
偶然看到这个经典问题的经典解决方法。
//本方法采用回溯方法,通过函数put_chess()对自身的递归来实现。递归深度为7
#include <math.h>
#include <stdio.h>
#define MAX 8
int board[MAX]; //皇后坐标数组,MAX为行数,board[MAX]为列数
int sum=0;
void show_result();
int check_cross(int n);
void put_chess(int n);
main()
{
put_chess(0);
printf("%d",sum);
getch();
return;
}
void show_result()
{
int i;
for(i=0;i<MAX;i++)
printf("(%d,%d)",i,board[i]);
printf("\n");
sum++;
}
int check_cross(int n)
{
int i;
for(i=0;i<n;i++)
{
if(board[i]==board[n]||(n-i)==abs(board[i]-board[n]))
return 1;
}
return 0;
}
void put_chess(int n)
{
int i;
for(i=0;i<MAX;i++)
{
board[n]=i;
if(!check_cross(n))
{
if(n==MAX-1)
show_result();
else
put_chess(n+1);
}
}
}
//共92种结果
GFKQnfoL.txt (822 Bytes) [分享]经典问题——八皇后问题


搜索更多相关主题的帖子: 皇后 经典 分享 
2006-02-21 19:27
shuimeijia
Rank: 1
等 级:新手上路
帖 子:2
专家分:0
注 册:2007-6-6
收藏
得分:0 
回复:(shensheng4)[分享]经典问题——八皇后问题

但是我运行不了.
那个getch();有问题

2007-06-06 20:35
蓝带
Rank: 1
等 级:新手上路
帖 子:10
专家分:0
注 册:2008-6-12
收藏
得分:0 
加一个头文件就好了
#include<conio.h>

还有建议把主函数写成  void 类型的,同时把主函数最后一行的 return  去掉
2008-06-13 01:01
liyanhong
Rank: 3Rank: 3
来 自:水星
等 级:禁止访问
威 望:8
帖 子:1867
专家分:0
注 册:2008-5-3
收藏
得分:0 
不錯
收藏了

有空再發(多解最好)

[[it] 本帖最后由 liyanhong 于 2008-6-13 02:18 编辑 [/it]]

爱上你 是 我的错  可是离 开  又舍不得  听着你为我写的歌     好难过
如果说 我说如果  我们还 能  重新来过   不去计 较 谁对谁错  会怎么做
2008-06-13 01:09
heimodao
Rank: 3Rank: 3
等 级:论坛游侠
帖 子:88
专家分:172
注 册:2011-4-8
收藏
得分:0 
把getch()改成getchar()就行
2011-04-22 17:46
快速回复:[分享]经典问题——八皇后问题
数据加载中...
 
   



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

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