小編給大家分享一下C語言實(shí)現(xiàn)五子棋游戲的案例,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

五子棋簡單功能實(shí)現(xiàn)具體內(nèi)容如下
游戲功能演示

代碼如下:
#include <stdio.h>
#include <stdlib.h>
#include <stdbool.h>
#include <getch.h>
// 棋盤
char board[15][15];
// 棋子坐標(biāo)
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(" -----------請(qǐng)%c落子-----------\n",role);
for(;;)
{
//通過光標(biāo)下棋
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勝利,游戲結(jié)束!\n",role);
return 0;
}
role = '@'==role?'#':'@';
}
}
當(dāng)前標(biāo)題:C語言實(shí)現(xiàn)五子棋游戲的案例-創(chuàng)新互聯(lián)
分享URL:http://chinadenli.net/article14/ddhgge.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供定制開發(fā)、App開發(fā)、網(wǎng)站導(dǎo)航、Google、App設(shè)計(jì)、網(wǎng)站策劃
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容