博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
八皇后問題 (C語言递归實現 回溯法)
阅读量:5252 次
发布时间:2019-06-14

本文共 1152 字,大约阅读时间需要 3 分钟。

八皇后问题是一个以国际象棋为背景的问题:怎样可以在 8×8 的国际象棋棋盘上放置八个皇后,使得不论什么一个都无法直接吃掉其它的皇后?为了达到此目的。任两个皇后都不能处于同一条横行、纵行或上。現在要統計出全部的可行方案的總數。并且輸出每一種方案皇后擺放的坐標;

代碼詳細解析:

#include 
#include
#include
#include
#include
#define MAXN 8 //MAXN為最大皇后數。棋盤最大坐標#define RST(N)memset(N, 0, sizeof(N))using namespace std;int queen[MAXN], res = 0; //記錄皇后所在的縱坐標,方案個數void display() //輸出一種可用方案所有皇后的坐標{ for(int i=0; i

printf("\n") : printf(" "); } for(int i=0; i<55; i++) printf("~"); printf("\n"); res++; } bool check(int position) //判斷當前position之前的列能否夠放置皇后 { for(int i=0; i<position; i++) { //分別判斷當前列以及對角線是否有皇后佔用 if(queen[i] == queen[position] || abs(queen[i]-queen[position]) == (position-i)) return false; } return true; } void put(int position) //回溯,繼續嘗試皇后所在行的位置,position為橫坐標喔 { for(int i=0; i<MAXN; i++) { queen[position] = i; //將皇后擺到當前行的不同列位置 if(check(position)) { if(position == MAXN-1) display(); //所有擺好 else put(position+1); //繼續擺放下一個皇后 } } } int main() { put(0); //從初始位置進行擺放 printf("%d\n", res); //輸出最後可行的方案總數 return 0; }

转载于:https://www.cnblogs.com/zsychanpin/p/7326857.html

你可能感兴趣的文章
关于收费软件
查看>>
javascript之Style物
查看>>
图的深度优先遍历
查看>>
C# 之 提高WebService性能大数据量网络传输处理
查看>>
[bzoj1004] [HNOI2008] Cards
查看>>
原生HttpClient详细使用示例
查看>>
几道面试题
查看>>
Factory Design Pattern
查看>>
python中贪婪与非贪婪
查看>>
guava API整理
查看>>
jquery mobile
查看>>
如何在vue单页应用中使用百度地图
查看>>
P1192-台阶问题
查看>>
一、使用pip安装Python包
查看>>
spring与quartz整合
查看>>
Kattis之旅——Eight Queens
查看>>
3.PHP 教程_PHP 语法
查看>>
Duilib扩展《01》— 双击、右键消息扩展
查看>>
利用Fiddler拦截接口请求并篡改数据
查看>>
python习题:unittest参数化-数据从文件或excel中读取
查看>>