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://myzitong.com/article/ddhgge.html