溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

C語言實現(xiàn)五子棋游戲的案例

發(fā)布時間:2020-08-25 09:35:55 來源:億速云 閱讀:250 作者:小新 欄目:開發(fā)技術

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

五子棋簡單功能實現(xiàn)具體內容如下

游戲功能演示

C語言實現(xiàn)五子棋游戲的案例

代碼如下:

#include <stdio.h>
#include <stdlib.h>
#include <stdbool.h>
#include <getch.h>
// 棋盤
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&#63;'#':'@';
 }
}

以上是C語言實現(xiàn)五子棋游戲的案例的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業(yè)資訊頻道!

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI