C語言實(shí)現(xiàn)簡易五子棋
本文實(shí)例為大家分享了C語言實(shí)現(xiàn)簡易五子棋的具體代碼,供大家參考,具體內(nèi)容如下
#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
#include<stdlib.h>
#include<time.h>
#define ROW 5
#define COL 5
char g_broad[ROW][COL];
void menu();
void menu()
{
printf("-----------------------\n");
printf("------1.開始游戲-------\n");
printf("------0.結(jié)束游戲-------\n");
printf("-----------------------\n");
printf("請輸入您的選擇:");
}
void Init(char broad[ROW][COL])
{
for (int row = 0; row < ROW; ++row)
{
for (int col = 0; col < COL; ++col)
{
broad[row][col] = ' ';
}
}
}
void print(char broad[ROW][COL])
{
for (int row = 0; row < ROW; ++row)
{
printf("| %c | %c | %c | %c | %c |\n", broad[row][0],
broad[row][1], broad[row][2], broad[row][3],
broad[row][4]);
if (row != ROW - 1)
{
printf(" ---|---|---|---|--- \n");
}
}
}
void playermove(char broad[ROW][COL])
{
printf("玩家落子:\n");
while (1)
{
printf("玩家請輸入一組坐標(biāo):(row col)");
int row = 0;
int col = 0;
scanf("%d %d", &row, &col);
if (row < 0 || row >= ROW || col < 0 || col >= COL)
{
printf("您輸入的坐標(biāo)非法,請重新輸入:\n");
continue;
}
else if (broad[row][col] != ' ')
{
printf("該位置已經(jīng)被占用,請重新輸入:\n");
continue;
}
else
{
broad[row][col] = 'x';
break;
}
}
}
void computermove(char broad[ROW][COL])
{
printf("電腦落子:\n");
while (1)
{
int row = rand() % ROW;
int col = rand() % COL;
if (broad[row][col] != ' ')
{
continue;
}
else
{
broad[row][col] = 'o';
break;
}
}
}
int Isfull(char broad[ROW][COL])
{
for (int row = 0; row < ROW; ++row)
{
for (int col = 0; col < COL; ++col)
{
if (broad[row][col] == ' ')
return 0;
}
}
return 1;
}
char checkwinner(char broad[ROW][COL])
{
for (int row = 0; row < ROW; ++row)
{
if (broad[row][0] == broad[row][1]
&& broad[row][0] == broad[row][2]
&& broad[row][0] == broad[row][3]
&& broad[row][0] == broad[row][4]
&& broad[row][0] != ' ')
{
return broad[row][0];
}
}
for (int col = 0; col < COL; ++col)
{
if (broad[0][col] == broad[1][col]
&& broad[0][col] == broad[2][col]
&& broad[0][col] == broad[3][col]
&& broad[0][col] == broad[4][col]
&& broad[0][col] != ' ')
{
return broad[0][col];
}
}
if (broad[0][0] == broad[1][1]
&& broad[0][0] == broad[2][2]
&& broad[0][0] == broad[3][3]
&& broad[0][0] == broad[4][4]
&& broad[0][0] != ' ')
{
return broad[0][0];
}
if (broad[0][4] == broad[1][3]
&& broad[0][4] == broad[2][2]
&& broad[0][4] == broad[3][1]
&& broad[0][4] == broad[4][0]
&& broad[4][0] != ' ')
{
return broad[4][0];
}
if (Isfull(broad))
{
return 'p';
}
else
return ' ';
}
int main()
{
srand((unsigned int)time(0));
int input = 0;
menu(g_broad); //初始化棋盤,將棋盤初始化成' '
Init(g_broad);
scanf("%d", &input);
char winner = ' ';
while (input)
{
//第一次打印棋盤
print(g_broad);
//玩家輸入,提示玩家輸入一組坐標(biāo),檢查游戲是否結(jié)束
playermove(g_broad);
winner = checkwinner(g_broad);
if (winner != ' ')
{
break;
}
//電腦輸入,瞎下,檢查游戲是否結(jié)束
computermove(g_broad);
winner = checkwinner(g_broad);
if (winner != ' ')
{
break;
}
}
if (winner == 'x')
{
printf("玩家勝利!\n");
print(g_broad);
}
if (winner == 'o')
{
printf("電腦勝利!\n");
print(g_broad);
}
if (winner == 'p')
{
printf("和棋!\n");
print(g_broad);
}
if (winner == ' ')
{
printf("游戲結(jié)束!goodbay~\n");
return 0;
}
return 0;
}
游戲運(yùn)行結(jié)果如下:



注:使用宏定義可以擴(kuò)充棋盤
更多有趣的經(jīng)典小游戲?qū)崿F(xiàn)專題,分享給大家:
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
C/C++?QT實(shí)現(xiàn)自定義對話框的示例代碼
對話框分為多種,常見的有通用對話框,自定義對話框,模態(tài)對話框,非模態(tài)對話框等,本文主要介紹了QT自定義對話框,感興趣的可以了解一下2021-11-11
C++寫時拷貝實(shí)現(xiàn)原理及實(shí)例解析
這篇文章主要介紹了C++寫時拷貝實(shí)現(xiàn)原理及實(shí)例解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2020-06-06
C語言實(shí)現(xiàn)點(diǎn)餐系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了C語言實(shí)現(xiàn)點(diǎn)餐系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2019-11-11
簡單總結(jié)C語言中的運(yùn)算符優(yōu)先級
這篇文章主要介紹了C語言中的運(yùn)算符優(yōu)先級,文中簡單總結(jié)了一些常用運(yùn)算符的優(yōu)先級順序以及記憶技巧,需要的朋友可以參考下2016-05-05
C語言數(shù)據(jù)結(jié)構(gòu)之鏈隊(duì)列的基本操作
這篇文章主要為大家介紹了C語言之鏈隊(duì)列的基本操作,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助2021-12-12
簡單了解C語言中直接插入排序與直接選擇排序?qū)崿F(xiàn)
這篇文章主要介紹了C語言中直接插入排序與直接選擇排序?qū)崿F(xiàn),插入排序的基本操作就是將一個數(shù)據(jù)插入到已經(jīng)排好序的有序數(shù)據(jù)中,從而得到一個新的、個數(shù)加一的有序數(shù)據(jù),需要的朋友可以參考下2016-03-03

