动态网站制作指南 [  QQ表情  ]
[ 投票调查 ]
[ 企业邮箱 ]
[ 网站空间 ]
网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
ASP源码 | .Net源码 | PHP源码 | JSP源码 | JAVA源码 | CGI源码 | VB源码 | C++源码 | Delphi源码 | PB源码 | VF源码 | 汇编 | 服务器
电脑书籍下载:程序设计书籍 | 数据库教程书籍 | 平面与多媒体书籍 | 网络通讯书籍 | 系统管理书籍 | 网络安全书籍 | 认证考试书籍
Firefox | IE | Maxthon | 迅雷 | 电驴 | BitComet | FlashGet | QQ | QQ空间 | Vista | 输入法 | Ghost | Word | Excel | wps | Powerpoint
asp | .net | php | jsp | Sql | c# | Ajax | xml | Dreamweaver | FrontPages | Javascript | css | photoshop | fireworks | Flash | Cad | Discuz!
当前位置 > 网站建设学院 > 网络编程 > C/C++教程
Tag:注入,存储过程,分页,安全,优化,xmlhttp,fso,jmail,application,session,防盗链,stream,无组件,组件,md5,乱码,缓存,加密,验证码,算法,cookies,ubb,正则表达式,水印,索引,日志,压缩,base64,url重写,上传,控件,Web.config,JDBC,函数,内存,PDF,迁移,结构,破解,编译,配置,进程,分词,IIS,Apache,Tomcat,phpmyadmin,Gzip,触发器,socket
网络编程:ASP教程,ASP.NET教程,PHP教程,JSP教程,C#教程,数据库,XML教程,Ajax,Java,Perl,Shell,VB教程,Delphi,C/C++教程,软件工程,J2EE/J2ME,移动开发
文章搜索服务
邮件订阅
输入你的邮件地址,
你将不会错过任何关于:
[ C/C++教程 ]的信息



本月文章推荐
.理解内联函数inline在C++中的用法.
.利用C++编写一个猜字游戏.
.全国计算机编程大赛复赛试题2.
.常用的BCB & Delphi&n.
.编程资源收集.
.递归找迷宫.
.正确使用 C++Builder组件缩.
.C++入门解惑——为什么学习C++.
.用Delphi程序获取拨号连接的动态.
.使用存储过程时一个错误的解决方.
.C++内存对象大会战.
.奇技淫巧C++之语法魔力球.
.C语言库函数(P类字母).
.C语言初学者入门讲座 第十六讲 文.
.C++箴言:将强制转型减到最少.
.打印日历.
.掷骰子.
.链表的c语言实现(五).
.C语言库函数 (B类字母).
.在StringGrid中用右键菜单实现复.

八皇后问题的非递归实现

发表日期:2008-3-8 |



  我们都知道八皇后问题是一个很经典的问题,当时很多解决八皇后问题的编程解法都是用递归解法,下面我用非递归的解法来实现如下:

  其中有关设置标志位来表示该位是否可以下皇后的原理,请看郑启华的《pascal程序设计(第二版)>〉清华大学出版社出版的。代码如下:

#include

#define available 1 //用来标志该位是否可用,availabel表示可用,unailable表示不可


#define unavailable 0

#define true 1

#define false 0

int j,top=-1,flag,i,is_pop,total=0;
  // top用来保存栈顶指针,flag用来说明该次是否成功下了一个皇后
    //is_pop用来说明是否把栈弹出,total用来保存共有多少种下法
    //i用来保存下一次皇后应下的列

int stack[8],a[15],b[15],c[7];
   //stack保存皇后的位置,a,b,c三个数住用来保存该位是否可以下皇后

void init(void);//初始化各位状态,使之可以下皇后

void release (void);//当该列都不能下皇后,则解除上次下皇后试对相关位的锁定

main()

{

  cout<
  init();

  is_pop=false;//初始化

  for( ; ;)

  {

   do {

    for (j=is_pop? stack[i]+1:0;j<=7;j++)

     if (a[i+j]&&b[i-j+7]&&c[j])//判定该位是否可用
      {//若可用,则栈顶指针上移,在该位存入皇后号

      top++;

      stack[top]=j;

      a[i+j]=b[i-j+7]=c[j]=unavailable;//并把相关位设为不可用

      i++;//i指向下一个应填入皇后德列

      flag=true;//设标志,说明成功

      is_pop=false;

      break;//则直接退出循环

     }

    if (!flag)//若不成功,则释放被锁定的位

     release();

    flag=false;

    if (stack[0]+1==8&&top==-1)//若第一列也没有位置可以放皇后,

      goto END; //则说明没有其他的放法了,则退出

   }

   while (top!=7);

   for (int k=0;k<=7;k++)

    cout

上一篇:利用C语言小程序来解决大问题 人气:372
下一篇:探索C++的秘密之详解extern “C” 人气:185
浏览全部C/C++的内容 Dreamweaver插件下载 常用网页广告代码全集
  最新网站源码 最新软件下载
2008-7-6 飞天论坛FTBBS ASP v6.3 Build 0
2008-7-6 飞天论坛FTBBS ASP v6.3 Build 0
2008-7-6 飞天论坛FTBBS ASP v6.8 Build 0
2008-7-6 讯息内容管理系统 v2.1
2008-7-6 三五电影程序 v2.0
2008-7-6 神鹰腾讯小说小偷 v3.0
2008-7-6 EasyIDE Framework v1.0 Build 2
2008-7-6 品告CMS系统(电影版) v0.9
2008-7-6 QQ自动登录器 C# 源码 v1.0
2008-7-5 AgileMessenger即时通讯工具 v1.
2008-7-5 GoodCalculator2.0版固件计算器
2008-7-5 RepoName源地址搜索工具 v1.21b
2008-7-5 AgileMessenger即时通讯工具 v1.
2008-7-5 TouchCopy多媒体管理软件 v3.13完
2008-7-5 VideosTone视频铃声 v1.1汉化破解
2008-7-5 TouchPad触摸板 v4.44破解版
2008-7-5 VideosTone破解补丁 v1.0
2008-7-5 Feeds GoogleReader客户端 v0.4.3


  发表评论
姓 名: 验证码:
内 容:
[ 汉字翻译拼音 ] [ 广告代码 ] [ 符号对照表 ] [ 进制转换 ] [ 经典小工具 ] [ 个税计算 ] [ 汉字简繁转换 ] [ 普通单位换算 ] [ 公制单位换算 ]
[ 生辰老黄历 ] [ 国内电话区号 ] [ 国家代码与域名缩写 ] [ 文字加密解密 ] [ 健康查询 ] [ 万年历 ] [ 手机号码查询 ] [ ip搜索 ] [ Google PR查询 ]
业务联系 | 广告刊登 | 频道合作 | 投稿荐稿 | 联系方式 | 加入收藏 | RSS订阅
Copyright © 2000-2008 www.knowsky.com All rights reserved | 网络实名:动态网站制作指南 | 沪ICP备05001343号
ホームページ制作 不動産検索システム 求人情報