中山比尔科技 / 中山华盛科技有限公司 中山比尔/中山华盛科技有限公司   中山比尔/中山华盛科技有限公司 设为主页  |  加入收藏  
  中山比尔/中山华盛科技有限公司
 
中山华盛科技有限公司
ERP软件
POS软件
其他硬件
解决方案
Linux/Unix
 
ERP软件
ERP管理系统解决方案(分模块)
服装ERP管理软件解决方案
电子厂ERP管理软件解决方案
灯饰厂ERP管理软件解决方案
鞋业ERP管理软件解决方案
卫浴洁具ERP管理软件解决方案
POS软件
商场百货总部-分店连锁解决方案
商场百货POS管理软件解决方案
超市POS管理软件解决方案
连锁店总部-分店解决方案
连锁店POS管理软件解决方案
服装连锁POS管理软件解决方案
连锁型会员解决方案
POS硬件
商业POS机
商业数据中心服务器
其他硬件
工业型-数据采集器-HT3600
商业型-数据采集器-HT3300
条形码打印机-斑马Zebra888
条形码打印机-斑马Zebra140XI
条形码打印机-斑马Zebra170XI
条形码打印机-TSC 243E
条形码打印机-东芝 TEC B-452
条形码打印机-立象 OS-214
条形码阅读器-Metrologic6130
条形码阅读器-Argox RF800
条形码阅读器-SymbolLs4004P
解决方案
企业网络解决方案
ICEFLOW VPN应用
VPN在DRP连锁分销管理中应用
知识平台
DELPHI编写邮件特快专递程序
DELPHI中数据的自动录入
DELPHI访问数据库结构
DELPHI的"八皇后"问题
API实现在MSN的信息提示
DELPHI编写蠕虫病毒浅析
开源软件-Linux/Unix
三十种Linux发行版名称含义祥解
站在开源社区,建立开放新世界
从Windows转向UNIX的一些困惑
Linux系统更耐网络攻击
开源开发模式是否适合商业用户
开源程序应用仍然有待改善
 
 
 
客户案例
   
  您现在的位置是: 中山华盛科技主页 - 软件开发 / 知识平台 - 基于DELPHI的"八皇后"问题动态实现
 
   
 

基于DELPHI的"八皇后"问题动态实现

 
http://dev.21tx.com 2006年08月26日 计算机与信息技术 左才文
 

摘要 对于八皇后问题的实现,如果结合动态的图形演示,则可以使算法的描述更形象、更生动,使教学能产生良好的效果。

  关键词 八皇后问题 冲突 数据结构 线程类

   八皇后问题是一个古老而著名的问题,是回溯算法的典型例题。该问题是十九世纪著名的数学家高斯1850年提出:在8X8格的国际象棋上摆放八个皇后,使其不能互相攻击,即任意两个皇后都不能处于同一行、同一列或同一斜线上,问有多少种摆法。

   下面用 Delphi 6实现的八皇后问题的动态图形程序,能够演示全部的92组解。八皇后问题动态图形的实现,主要应解决以下几个问题。

冲突

   包括行、列、两条对角线:

   (1)列:规定每一列放一个皇后,不会造成列上的冲突;

   (2)行:当第i行被某个皇后占领后,则同一行上的所有空格都不能再放皇后,要把以i

   为下标的标记置为被占领状态;

   (3)对角线:对角线有两个方向。在同一对角线上的所有点(设下标为(i,j)),要么(i+j)是常数,要么(i-j)是常数。因此,当第i个皇后占领了第j列后,要同时把以(i+j)、(i-j)为下标的标记置为被占领状态。

数据结构

   为了对该问题的执行过程进行控制,需将该问题中的主要数据及相应的操作定义成一个线程类。方法:在New菜单中单击Other选项,在对话框中选Thread object,在classs name中输线程类的类名。具体定义如下:

type
  Tbhh = class(TThread)

private
  a:array[1..8,1..8]of integer;
  tt:integer;
  q,c:Tbitmap;
  procedure prt;
  function pd(i,j:integer):boolean;
  procedure hsu(i:integer);
protected
  procedure Execute; override;
public
  constructor create(flag:boolean);
end;

var
  dstep:boolean;

解决冲突的具体函数

function pd(i,j:integer):boolean;
  var i1,j1:integer;
begin
  pd:=true;
  if i<>1
  then begin for i1:=1 to i-1 do for j1:=1 to 8 do
  if a[i1,j1]=1
  then begin if j1=j then pd:=false else if abs(i1-i)=abs(j1-j)then pd:=false end
  end
end;

棋盘与棋子的图片(需要用画图程序作出)、生成、装入及显示过程如下:

procedure TForm1.PaintBox1Click(Sender: TObject);
  var q:tbitmap;
begin
  q:=tbitmap.create;
  q.loadfromfile('e:\八皇后\backimg.bmp');
  paintbox1.canvas.Draw(0,0,q);
end;
end.


组件设置

   paintbox1:绘图板,显示当前的合法布局。

   Label1:文字标签,显示当前合法布局的序号。

   Button1,button2,button3,button4:开始、单幅、连续、退出按纽。

      程序清单:

   (1)代码单元unit1:

procedure TForm1.Button1Click(Sender: TObject);
begin
  dstep:=true;
  bhh:=tbhh.create(false);
  button1.enabled:=false;
  button2.enabled:=true;
  button3.enabled:=true;
end;

procedure TForm1.Button2Click(Sender: TObject);
begin
  if dstep=false then begin bhh.suspend; dstep:=true end
  else bhh.resume
end;

procedure TForm1.Button3Click(Sender: TObject);
begin
  dstep:=false; bhh.resume;
end;

   (2)代码单元unit2:

uses unit1;
procedure Tbhh.Execute;
begin
  hsu(1);
  form1.button1.enabled:=true;
  form1.button2.enabled:=false;
  form1.button3.enabled:=false;
end;

procedure tbhh.prt;//显示
  var i,j,ix,iy:integer;
  s:real;iis:string[2];
begin
  str(tt:2,iis);
  form1.label1.caption:='第'+iis+'幅';
  form1.paintbox1.canvas.draw(0,0,q);
  for i:=1 to 8 do
   for j:=1 to 8 do
    if a[i,j]=1 then
    begin
     ix:=(i-1)*50+1;
     iy:=(j-1)*50+1;
     form1.paintbox1.canvas.draw(iy,ix,c);
    end;
    if dstep=true then suspend
    else begin s:=10; for i:=1 to 100000 do s:=s*s/s end;
   end;
   procedure tbhh.hsu(i:integer);//回溯求解
   var j:integer;
   begin
    if i>8 then begin tt:=tt+1; synchronize(prt)end
    else for j:=1 to 8 do
    begin a[i,j]:=1;if pd(i,j) then hsu(i+1);a[i,j]:=0;end
   end;
   constructor tbhh.create(flag:boolean);//创建该线程的一实例并对有关的变量进行初始化
  var i,j:integer;
  begin
   inherited create(flag);
   q:=tbitmap.create;q.loadfromfile('e:\八皇后\backing.bmp');
   c:=tbitmap.create;c.loadfromfile('e:\八皇后\queen.bmp');
   for i:=1 to 8 do
    for j:=1 to 8 do
     a[i,j]:=0; tt:=0;
    end;
   end.
 
 

 

 
 
网站导航: 首 页|关于我们|新闻中心|ERP软件产品|POS软件产品|硬件产品|客户案例|知识平台|软件下载|解决方案|服务与支持|联系我们|汇款帐号|工作机会|法律条款|网站地图|客户留言
   友情链接:
              汽车租赁      注册香港公司  上海网站建设  上海网站制作 上海网页制作 网站制作      无忧维修网   杭州送水站  POS系统       进销存软件    POS机
              电脑维修网    收银系统      更多友情链接   注册公司
     

Copyright@2006-2009 中山比尔/中山华盛科技有限公司版权所有 网站设计:中山华盛科技  网站优化:中山华盛科技
电话:  0760-8862282 / 0760-8161185 / 0760-8613158 / 0760-8150358 传真: 0760-8862049 / 0760-8615118 / 0760-8862049
地址:  广东省中山市西区西苑广场富荣阁17楼C座(技术部) / 广东省中山市石岐区永胜广场7楼C座(开发部)
        广东省中山市西区西苑电脑城1楼1029(门市) / 广东省中山市西区颐高数码广场1楼F08(门市)
联系人:汪经理 (13590742255) / 黄经理 (13590757383)