C語言實(shí)現(xiàn)三子棋游戲
本文實(shí)例為大家分享了C語言實(shí)現(xiàn)三子棋游戲的具體代碼,供大家參考,具體內(nèi)容如下
#include<stdio.h>
#include<stdlib.h>
#include<time.h>
void chess_board(char arr[3][3]) //打印棋盤
{
int i = 0;
int j = 0;
for (i = 0; i < 3; i++)
{
printf( " %c | %c | %c \n", arr [i][0], arr[i][1], arr[i][2]);
if (i<2)
printf( "---|---|---\n");
}
}
int success_or_failure(char arr[3][3]) //判斷勝負(fù)
{
int i = 0;
int j = 0;
for (i = 0; i < 3; i++)
{
if ((arr [i][0] == arr[i][1]) && ( arr[i][j] == arr [i][2]))
{
if (arr [i][0] == '#')
return 1; //用戶贏了
else if (arr[i][0] == '0')
return -1; //電腦贏了
}
}
for (j = 0; j < 3; j++)
{
if ((arr [0][j] == arr[1][j]) && ( arr[1][j] == arr [2][j]))
{
if (arr [0][j] == '#')
return 1; //用戶贏了
else if (arr[0][j] == '0')
return -1; //電腦贏了
}
}
if ((arr [0][0] == arr[1][1]) && ( arr[0][0] == arr [2][2]))
{
if (arr [1][1] == '#')
return 1; //用戶贏了
else if (arr[1][1] == '0')
return -1; //電腦贏了
}
if ((arr [0][2] == arr[1][1]) && ( arr[0][2] == arr [2][0]))
{
if (arr [1][1] == '#')
return 1; //用戶贏了
else if (arr[1][1] == '0')
return -1; //電腦贏了
}
for (i = 0; i < 3; i++)
{
for (j = 0; j < 3; j++)
{
if (arr [i][j] == ' ')
return 0; //都沒贏
}
}
return -2; //平局
}
int user_game(char arr[3][3]) //用戶輸入
{
int x = 0;
int y = 0;
while (1)
{
printf( "please user input:(x, y) ");
scanf( "%d%d", &x, &y);
printf( "\n");
if ((x<1 && x>3) || (y<1 && y>3)) //判斷用戶輸入的是否合法
{
printf( "地址無效,請重新輸入\n" );
break;
}
if (arr [x - 1][y - 1] == ' ') //判斷這個(gè)位置有沒有被占
{
arr[x - 1][y - 1] = '#' ;
break;
}
printf( "地址無效,請重新輸入\n" );
}
chess_board( arr);
int ret=success_or_failure(arr );
return ret;
}
int computer_game(char arr[3][3]) //電腦輸入
{
printf( "computer input:\n\n");
int x = 0;
int y = 0;
while (1)
{ //產(chǎn)生一個(gè)沒有被棋子占用的位置
srand(( unsigned)time(NULL ));
x = rand() % 3;
srand(( unsigned)time(NULL ));
y = rand() % 3;
if (arr [x][y] == ' ')
break;
}
arr[x][y]= '0' ;
chess_board(arr);
int ret=success_or_failure(arr);
return ret;
}
void init(char arr[][3]) //初始化棋盤
{
for (int i = 0; i < 3; i++)
{
for (int j = 0; j<3; j++)
{
arr[i][j] = ' ';
}
}
}
int main()
{
printf( "**********************\n"); //打印菜單
printf( "******* *******\n");
printf( "*******1.go 0.exit**\n");
printf( "******* *******\n");
printf( "**********************\n");
printf( "**********************\n\n\n");
char arr[3][3];
while (1)
{
init(arr); //初始化棋盤
int count = 0;
printf( "\nplease choice:1 or 0 : " );
scanf( "%d", &count); //選擇功能
if (count == 0)
{
exit( EXIT_FAILURE);
}
else if (count == 1)
{
printf( "\n****游戲開始****\n\n" );
while (1)
{ int n1 = user_game(arr);
{
if (n1 == 1)
{
printf( "****恭喜玩家贏了****\n" );
break;
}
}
int n2 = computer_game(arr);
{
if (n2 == -1)
{
printf( "****電腦贏了****\n" );
break;
}
}
if ((n1 == -2) || (n2 == -2))
{
printf( "*****平局******\n" );
break;
}
}
printf( "\n再來一局\n\n" );
}
return 0;
}
更多有趣的經(jīng)典小游戲?qū)崿F(xiàn)專題,分享給大家:
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
C語言的字符串函數(shù),內(nèi)存函數(shù)筆記詳解
這篇文章主要給大家介紹了關(guān)于C語言字符串/內(nèi)存的相關(guān)函數(shù),文中通過示例代碼總結(jié)的非常詳細(xì),對大家學(xué)習(xí)或者使用C語言具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧2021-09-09
C++使用LibCurl實(shí)現(xiàn)Web隱藏目錄掃描功能
LibCurl是一個(gè)開源的免費(fèi)的多協(xié)議數(shù)據(jù)傳輸開源庫,該框架具備跨平臺性,開源免費(fèi),并提供了包括HTTP、FTP、SMTP、POP3等協(xié)議的功能,本文將給大家介紹C++使用LibCurl實(shí)現(xiàn)Web隱藏目錄掃描功能2023-11-11
C語言的動態(tài)內(nèi)存分配及動態(tài)內(nèi)存分配函數(shù)詳解
這篇文章主要為大家詳細(xì)介紹了C語言的動態(tài)內(nèi)存分配及動態(tài)內(nèi)存分配函數(shù),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助2022-03-03
VSCode 使用 Code Runner 插件無法編譯運(yùn)行文件名帶空格的文件問題
這篇文章主要介紹了VSCode 使用 Code Runner 插件無法編譯運(yùn)行文件名帶空格的文件問題,本文通過圖文實(shí)例相結(jié)合給大家介紹的非常詳細(xì),需要的朋友可以參考下2021-07-07
超詳細(xì)分析C語言動態(tài)內(nèi)存管理問題
動態(tài)內(nèi)存是相對靜態(tài)內(nèi)存而言的。所謂動態(tài)和靜態(tài)就是指內(nèi)存的分配方式。動態(tài)內(nèi)存是指在堆上分配的內(nèi)存,而靜態(tài)內(nèi)存是指在棧上分配的內(nèi)存,本文帶你深入探究C語言中動態(tài)內(nèi)存的管理2022-04-04
C++代碼實(shí)現(xiàn)網(wǎng)絡(luò)Ping功能
這篇文章主要介紹了C++代碼實(shí)現(xiàn)網(wǎng)絡(luò)Ping功能,Ping命令被送到本地計(jì)算機(jī)的IP軟件,該命令永不退出該計(jì)算機(jī),本文給大家介紹的非常詳細(xì),需要的朋友參考下吧2021-08-08

