• 软件测试技术
  • 软件测试博客
  • 软件测试视频
  • 开源软件测试技术
  • 软件测试论坛
  • 软件测试沙龙
  • 软件测试资料下载
  • 软件测试杂志
  • 软件测试人才招聘
    暂时没有公告

字号: | 推荐给好友 上一篇 | 下一篇

turbo C动态演示八皇后

发布: 2007-7-01 20:40 | 作者: admin | 来源: | 查看: 18次 | 进入软件测试论坛讨论

领测软件测试网

   这是我数据结构课程设计的一部分,现拿出来与大家交流并希望能有人对其改进:

#include
#include
#include
#include
#define MAX 8
int board[MAX];

void Drow()
{
  int i;
  int Driver=VGA,Mode=VGAHI;
      initgraph(&Driver,&Mode,"d:\\TC3.0\\bgi");
      setfillstyle(SOLID_FILL,BLUE);
      bar(5,15,600,500);
      setcolor(YELLOW);
      for(i=0;i<=9;i++)
      {
  line(10,20+50*i,460,20+50*i);
      }
      for(i=0;i<=9;i++)
      {
  line(10+50*i,20,10+50*i,470);
      }
      line(460,20,560,20);
      line(10,470,560,470);
      line(560,470,560,20);
      setcolor(RED);
      outtextxy(465,30,"WuShangjie");
      outtextxy(465,45,"Eight Queue");
      outtextxy(465,60,"CopyRight1.0");

      outtextxy(415,440,"Start");
       outtextxy(385,440,"0");
       outtextxy(335,440,"1");
       outtextxy(285,440,"2");
       outtextxy(235,440,"3");
       outtextxy(185,440,"4");
       outtextxy(135,440,"5");
       outtextxy(85,440,"6");
       outtextxy(35,440,"7");

     outtextxy(415,455,"Point");
       outtextxy(435,390,"0");
       outtextxy(435,340,"1");
       outtextxy(435,290,"2");
       outtextxy(435,240,"3");
       outtextxy(435,190,"4");
       outtextxy(435,140,"5");
       outtextxy(435,90,"6");
       outtextxy(435,40,"7");
}
void DrowCircle(int i,int j)
{
  char text[80];
  setfillstyle(SOLID_FILL,YELLOW);
  setcolor(YELLOW);
  circle(385-50*i,395-50*j,15);
  floodfill(385-50*i,395-50*j,YELLOW);
  setcolor(RED);
  sprintf(text,"%d,%d",i,j);
  outtextxy(385-50*i-14,395-50*j,text);
}
void GiveDrowIn(int i,int j)
{
  setfillstyle(SOLID_FILL,BLUE);
  setcolor(BLUE);
  circle(385-50*i,395-50*j,15);
  floodfill(385-50*i,395-50*j,BLUE);
  outtextxy(385-50*i-14,395-50*j,"                   ");
}

void show_result()
{
     int j;
     for(j=0;j    {
    //  printf("(%d,%d)",j,board[j]);
 DrowCircle(j,board[j]);
    }
 getch();
     for(j=0;j    {
 GiveDrowIn(j,board[j]);
    }
 getch();
}
int check_cross(int n)
{
    int k;
    for(k=0;k       if(board[k]==board[n]||(n-k)==abs(board[k]-board[n]))
       return 1;
       }
       return 0;
}
void put_chess(int n)
{
     for(int l=0;l      board[n]=l;
  if(!check_cross(n)){
   if(n==MAX-1) {
    show_result();
   }
   else put_chess(n+1);
  }
     }
}
void main()
{
   Drow();
   put_chess(0);
   return;
// clrscr();
}


延伸阅读

文章来源于领测软件测试网 https://www.ltesting.net/


关于领测软件测试网 | 领测软件测试网合作伙伴 | 广告服务 | 投稿指南 | 联系我们 | 网站地图 | 友情链接
版权所有(C) 2003-2010 TestAge(领测软件测试网)|领测国际科技(北京)有限公司|软件测试工程师培训网 All Rights Reserved
北京市海淀区中关村南大街9号北京理工科技大厦1402室 京ICP备10010545号-5
技术支持和业务联系:info@testage.com.cn 电话:010-51297073

软件测试 | 领测国际ISTQBISTQB官网TMMiTMMi认证国际软件测试工程师认证领测软件测试网