/*
* 八皇后问题回溯法编程练习
* 在8×8的棋盘上,放置8个皇后,两个皇后之间不能两两攻击
* 也即,直线,垂直45度、135度方向不能出现两个皇后
*
* copyright Michael 2014-12-19
* QQ 1192065414
**/ #include <iostream>
#include <stack>
#include <stdlib.h>
#include <string.h>
using namespace std; struct Sposition
{
int iRow;
int iColumn;
}; /*
* 保存结果使用的栈
**/
stack<Sposition> ResultStack; /*
* 推断在水平方向x,垂直方向y,能否够放置新皇后
**/
bool JudgeIsAcceptable(int x ,int y)
{
struct Sposition pos; stack<Sposition> resultS(ResultStack);
int stackSize = resultS.size();
for ( ; stackSize > 0 ; --stackSize )
{
pos = resultS.top();
if( pos.iRow == x ) //推断同一直线上是否已经有皇后
{
return false;
} if( (x-pos.iRow) == (y-pos.iColumn) ) //推断45度角是否已经有皇后
{
return false;
} if( (x-pos.iRow) == (pos.iColumn-y) ) //推断-45度角是否已经有皇后
{
return false;
} resultS.pop();
} return true;
} /*
* 皇后放置算法
* 0 0 0...
* 0 0 0...
* 0 0 0...
* ......
* 遍历第0列,取第0列的第一个、第二个...
* 从第1列開始尝试,然后尝试第2列,当尝试到一列,8行都不能放置皇后,则回溯。返回前一列的下一行继续尝试
**/
void SolveQueue()
{
Sposition pos;
for (int i = 0 ; i < 8 ; ++i )
{
//The first line of the queue
pos.iRow = i;
pos.iColumn = 0;
ResultStack.push(pos); int x = 0; //标记当前行。0~7行
int y = 1; //标记当前列。0~7列
while( y<8 ) //从第一列開始
{
for ( ; x < 8 ; ++x ) //从第0行開始探索
{
if ( JudgeIsAcceptable(x,y) )
{
pos.iRow = x;
pos.iColumn = y;
ResultStack.push(pos); //放置完毕。输出结果
if ( 8 == ResultStack.size() )
{
while ( !ResultStack.empty() )
{
pos = ResultStack.top();
cout<<pos.iRow<<"\t"<<pos.iColumn<<endl;
ResultStack.pop();
}
}
x = 0; //这一列放置完毕,继续下一列放置
break;
}
} if ( 8 == x ) //这一列。8行都不能放置皇后,回溯到上一列的下一行
{
pos = ResultStack.top();
x = pos.iRow+1;
if ( 8 <= x )
{
y = y-2; //假设上一列放置的地方已经是最后一列。则无需继续尝试,应该回溯两列。从前两列继续尝试
ResultStack.pop();
pos = ResultStack.top();
x = pos.iRow+1;
}
else
{
--y; //回溯到前一列的下一行继续尝试
}
ResultStack.pop();
continue; //控制列数,不进行 ++y 操作
} ++y;;
} if ( (8 == y) && (ResultStack.size() != 8) ) //假设8行已经尝试完,可是放置不够8行,出错状态。处理下一种可能性
{
while ( !ResultStack.empty() )
{
ResultStack.pop();
}
} cout<<endl;
cout<<endl;
}
} int main()
{
SolveQueue();
}

8皇后-----回溯法C++编程练习的更多相关文章

  1. js实现八皇后,回溯法

    八皇后问题:将八个皇后摆在一张8*8的国际象棋棋盘上,使每个皇后都无法吃掉别的皇后,一共有多少种摆法? 两个皇后不能同时在同一行,同一列,和斜对角线的位置上,使用回溯法解决. 从第一行选个位置开始放棋 ...

  2. 回溯法解决N皇后问题(以四皇后为例)

    以4皇后为例,其他的N皇后问题以此类推.所谓4皇后问题就是求解如何在4×4的棋盘上无冲突的摆放4个皇后棋子.在国际象棋中,皇后的移动方式为横竖交叉的,因此在任意一个皇后所在位置的水平.竖直.以及45度 ...

  3. 『嗨威说』算法设计与分析 - 回溯法思想小结(USACO-cha1-sec1.5 Checker Challenge 八皇后升级版)

    本文索引目录: 一.回溯算法的基本思想以及个人理解 二.“子集和”问题的解空间结构和约束函数 三.一道经典回溯法题点拨升华回溯法思想 四.结对编程情况 一.回溯算法的基本思想以及个人理解: 1.1 基 ...

  4. 实现n皇后问题(回溯法)

    /*======================================== 功能:实现n皇后问题,这里实现4皇后问题 算法:回溯法 ============================= ...

  5. HDU 2553 n皇后问题(回溯法)

     DFS Time Limit:1000MS     Memory Limit:32768KB     64bit IO Format:%I64d & %I64u   Description ...

  6. 八皇后问题-回溯法(MATLAB)

    原创文章,转载请注明:八皇后问题-回溯法(MATLAB) By Lucio.Yang 1.问题描述 八皇后问题是十九世纪著名数学家高斯于1850年提出的.问题是:在8*8的棋盘上摆放8个皇后,使其不能 ...

  7. 算法——八皇后问题(eight queen puzzle)之回溯法求解

    八皇后谜题是经典的一个问题,其解法一共有种! 其定义: 首先定义一个8*8的棋盘 我们有八个皇后在手里,目的是把八个都放在棋盘中 位于皇后的水平和垂直方向的棋格不能有其他皇后 位于皇后的斜对角线上的棋 ...

  8. 回溯法求解n皇后和迷宫问题

    回溯法是一种搜索算法,从某一起点出发按一定规则探索,当试探不符合条件时则返回上一步重新探索,直到搜索出所求的路径. 回溯法所求的解可以看做解向量(n皇后坐标组成的向量,迷宫路径点组成的向量等),所有解 ...

  9. USACO 1.5.4 Checker Challenge跳棋的挑战(回溯法求解N皇后问题+八皇后问题说明)

    Description 检查一个如下的6 x 6的跳棋棋盘,有六个棋子被放置在棋盘上,使得每行,每列,每条对角线(包括两条主对角线的所有对角线)上都至多有一个棋子. 列号 0 1 2 3 4 5 6 ...

随机推荐

  1. 玩转Windows服务系列——Debug、Release版本的注册和卸载,及其原理

    原文:玩转Windows服务系列——Debug.Release版本的注册和卸载,及其原理 Windows服务Debug版本 注册 Services.exe -regserver 卸载 Services ...

  2. 4.2、Libgdx每个模块概述

    (原版的:http://www.libgdx.cn/topic/34/4-2-libgdx%E5%90%84%E4%B8%AA%E6%A8%A1%E5%9D%97%E6%A6%82%E8%A7%88) ...

  3. 2015年十大热门Android开源新项目

    2015年十大热门Android开源新项目 2015 即将结束,又到了大家喜闻乐见的年终盘点时刻啦,今天给大家盘点一下 2015 年 Android 开发领域新出现的 10 大热门开源项目.数据来自于 ...

  4. c# WinForm开发 DataGridView控件的各种操作总结(单元格操作,属性设置)

    一.单元格内容的操作 *****// 取得当前单元格内容 Console.WriteLine(DataGridView1.CurrentCell.Value); // 取得当前单元格的列 Index ...

  5. 从零開始制作H5应用(4)——V4.0,增加文字并给文字加特效

    之前,我们分三次完毕了我们第一个H5应用的三个迭代版本号: V1.0--简单页面滑动切换 V2.0--多页切换,透明过渡及交互指示 V3.0--加入loading,music及自己主动切换 这已经是一 ...

  6. uva 1434 - YAPTCHA(数论)

    题目链接:uva 1434 - YAPTCHA 题目大意:给定n和k,求题目中给定的式子S(n). 解题思路:威尔逊定理,x为素数时有,((x−1)!+1)%x==0,所以对于本题.假设3*k+7为素 ...

  7. Egret是一套完整的HTML5游戏开发解决方案

    Egret是一套完整的HTML5游戏开发解决方案.Egret中包含多个工具以及项目.Egret Engine是一个基于TypeScript语言开发的HTML5游戏引擎,该项目在BSD许可证下发布.使用 ...

  8. POJ 1753 位运算+枚举

    题意: 给出4*4的棋盘,只有黑棋和白棋,问你最少几步可以使棋子的颜色一样. 游戏规则是:如果翻动一个棋子,则该棋子上下左右的棋子也会翻一面,棋子正反面颜色相反. 思路: 都是暴搜枚举. 第一种方法: ...

  9. docker 的安装

    官方站点上有各种环境下的 安装指南,这里主要介绍下Ubuntu和CentOS系列的安装. Ubuntu 系列安装 Docker 通过系统自带包安装 Ubuntu 14.04 版本号系统中已经自带了 D ...

  10. UVa 884 - Factorial Factors

    题目:输出n!中素数因数的个数. 分析:数论.这里使用欧拉筛法计算素数,在计算过程中求解就可以. 传统筛法是利用每一个素数,筛掉自己的整数倍: 欧拉筛法是利用当前计算出的全部素数,乘以当前数字筛数: ...