C語言實(shí)現(xiàn)三子棋小游戲
更新時(shí)間:2020年03月21日 13:39:04 作者:宇哲_安菲爾德
這篇文章主要為大家詳細(xì)介紹了C語言實(shí)現(xiàn)三子棋小游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
在這里我們要寫出一個(gè)三子棋的小游戲,能夠?qū)崿F(xiàn)所需要的三字連珠的功能,并且可以使得游戲讓玩家進(jìn)行選擇是否繼續(xù)的功能。
代碼:
#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
#include<stdlib.h>
#include<time.h>
#define ROW 3
#define COL 3
void init_board(char arr[ROW][COL])
{
int i=0;
int j=0;
for (i = 0; i < ROW; i++)
{
for (j = 0; j < COL; j++)
{
arr[i][j] = ' ';
}
}
}
void display_board(char arr[ROW][COL])
{
int i = 0;
for (i = 0; i < ROW; i++)
{
printf(" %c|%c |%c\n", arr[i][0], arr[i][1], arr[i][2]);
if (i < 2)
{
printf("--|--|--");
}
printf("\n");
}
}
void player_chess(char arr[ROW][COL])
{
int x = 0;
int y = 0;
while (1)
{
printf("請(qǐng)輸入你所要下棋的方位:");
scanf("%d%d", &x, &y);
x--;
y--;
if (arr[x][y] == ' ')
{
arr[x][y] = '#';
break;
}
else
{
printf("這個(gè)位置已經(jīng)被占,請(qǐng)重新下棋。\n");
continue;
}
}
}
void computer_chess(char arr[ROW][COL])
{
srand((unsigned)time(NULL));
while (1)
{
int x = 0;
int y = 0;
srand((unsigned)time(NULL));
x = rand() % 3;
y = rand() % 3;
if (arr[x][y] == ' ')
{
arr[x][y] = '@';
break;
}
else
{
if (check_full(arr) == 0)
{
continue;
}
else
{
break;
}
}
}
}
int check_full(char arr[ROW][COL])
{
int i = 0;
int j = 0;
for (i = 0; i < ROW; i++)
{
for (j = 0; j < COL; j++)
{
if (arr[i][j] == ' ')
{
return 0;
}
}
}
return 1;
}
char check_win(char arr[ROW][COL])
{
int i = 0;
int ret = 0;
for (i = 0; i < ROW; i++)
{
if ((arr[i][0] == arr[i][1]) && (arr[i][2] == arr[i][1]))
{
return arr[i][0];
}
}
for (i = 0; i < COL; i++)
{
if ((arr[0][i] == arr[1][i]) && (arr[2][i] == arr[1][i]))
{
return arr[0][i];
}
}
if ((arr[0][0] == arr[1][1]) && (arr[1][1] == arr[2][2]))
{
return arr[0][0];
}
if ((arr[0][2] == arr[1][1]) && (arr[1][1] == arr[2][0]))
{
return arr[2][0];
}
ret = check_full(arr);
if (ret == 1)
{
return 'q';
}
return ' ';
}
int main()
{
char arr[ROW][COL] = { 0 };
int input = 1;
while (input)
{
printf("請(qǐng)選擇是否開始游戲:");
printf("1:繼續(xù)游戲,0:結(jié)束游戲");
scanf("%d", &input);
switch (input)
{
case 1:{
char ret = 0;
init_board(arr);
do
{
display_board(arr);
player_chess(arr);
display_board(arr);
if (check_win(arr) != ' ')
{
ret = check_win(arr);
break;
}
computer_chess(arr);
ret = check_win(arr);
} while (ret == ' ');
display_board(arr);
if (ret == '#')
{
printf("玩家贏的游戲\n");
}
else if (ret == '@')
{
printf("電腦贏的游戲\n");
}
else if (ret == 'q')
{
printf("游戲平局\n");
}
}
break;
case 0:
break;
}
}
system("pause");
return 0;
}
效果圖:

程序如果有不足之處,希望大家能夠多多指出來。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Visual Studio 2022配置fftw第三方庫的詳細(xì)過程
FFTW是一個(gè)可以進(jìn)行可變長(zhǎng)度一維或多維DFT的開源C程序庫,是目前最快的FFT算法實(shí)現(xiàn),本文簡(jiǎn)述了在Windows平臺(tái)上,如何在C++中調(diào)用FFTW,所使用的IDE為Visual Studio 2022,感興趣的朋友一起看看吧2024-06-06
C語言數(shù)據(jù)結(jié)構(gòu)之圖的遍歷實(shí)例詳解
這篇文章主要介紹了C語言數(shù)據(jù)結(jié)構(gòu)之圖的遍歷實(shí)例詳解的相關(guān)資料,需要的朋友可以參考下2017-07-07
C++使用read()和write()讀寫二進(jìn)制文件
以文本形式讀寫文件和以二進(jìn)制形式讀寫文件的區(qū)別,并掌握了用重載的?>>?和?<<?運(yùn)算符實(shí)現(xiàn)以文本形式讀寫文件,在此基礎(chǔ)上,本節(jié)將講解如何以二進(jìn)制形式讀寫文件2023-10-10
C/C++實(shí)現(xiàn)通訊錄管理系統(tǒng)(附源碼)
這篇文章主要為大家詳細(xì)介紹了如何利用C++實(shí)現(xiàn)通訊錄管理系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-12-12
C++將二叉樹轉(zhuǎn)為雙向鏈表及判斷兩個(gè)鏈表是否相交
這篇文章主要介紹了C++將二叉樹轉(zhuǎn)為雙向鏈表及判斷兩個(gè)鏈表是否相交的方法,文中還給出了求兩個(gè)鏈表相交的第一個(gè)節(jié)點(diǎn)列的實(shí)現(xiàn)方法,需要的朋友可以參考下2016-02-02

