189 8069 5689

C语言实现五子棋游戏的案例-创新互联

小编给大家分享一下C语言实现五子棋游戏的案例,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!

创新互联建站坚持“要么做到,要么别承诺”的工作理念,服务领域包括:成都做网站、网站制作、企业官网、英文网站、手机端网站、网站推广等服务,满足客户于互联网时代的潜江网站设计、移动媒体设计的需求,帮助企业找到有效的互联网解决方案。努力成为您成熟可靠的网络建设合作伙伴!

五子棋简单功能实现具体内容如下

游戏功能演示

C语言实现五子棋游戏的案例

代码如下:

#include 
#include 
#include 
#include 
// 棋盘
char board[15][15];
// 棋子坐标
char kx = 7 , ky = 7;
// 角色
char role = '@';
// 显示棋盘
void show_board(void)
{
 system("clear");
 for(int i=0; i<15; i++)
 {
 for(int j=0; j<15; j++)
 {
 if(board[i][j])
 {
 printf(" %c",board[i][j]);
 }
 else
 {
 printf(" *");
 }
 }
 printf("\n");
 }
}
// 落子
void get_key(void)
{
 printf(" -----------请%c落子-----------\n",role);
 for(;;)
 {
 //通过光标下棋
 printf("\33[%hhd;%hhdH",kx+1,(ky+1)*2);
 switch(getch())
 {
 case 183: kx>0 && kx--; break;
 case 184: kx<14 && kx++; break;
 case 185: ky<14 && ky++; break;
 case 186: ky>0 && ky--; break;
 case 10: if(!board[kx][ky])
 {
 board[kx][ky] = role;
 return;
 }
 }
 }
}
int count_eqkey(int ox,int oy)
{
 int count = 0;
 for(int x=kx+ox,y=ky+oy; x>=0 && x<15 && y>=0 && y<15 &&
 board[x][y]==board[kx][ky]; x+=ox,y+=oy)
 {
 count++;
 }
 return count;
}
// 检查五子
bool check_board(void)
{
 if(count_eqkey(0,-1)+count_eqkey(0,1) >= 4)
 return true;
 if(count_eqkey(-1,0)+count_eqkey(1,0) >= 4)
 return true;
 if(count_eqkey(-1,-1)+count_eqkey(1,1) >= 4)
 return true;
 if(count_eqkey(-1,1)+count_eqkey(1,-1) >= 4)
 return true;
 return false;
}
int main()
{
 for(;;)
 {
 show_board();
 get_key(); 
 if(check_board())
 {
 show_board();
 printf("恭喜%c胜利,游戏结束!\n",role);
 return 0;
 }
 role = '@'==role?'#':'@';
 }
}

网站标题:C语言实现五子棋游戏的案例-创新互联
本文路径:http://cdxtjz.cn/article/ddhgge.html

其他资讯