C語(yǔ)言實(shí)現(xiàn)簡(jiǎn)單三子棋程序
使用C語(yǔ)言實(shí)現(xiàn)簡(jiǎn)單的三子棋程序,主要是對(duì)二維數(shù)組的運(yùn)用,我們需要一個(gè)頭文件,兩個(gè)源文件來實(shí)現(xiàn)。
game.h //包含函數(shù)的聲明,宏定義
test.c //包含主函數(shù),函數(shù)調(diào)用
game.c //包含函數(shù)的定義
整體思路
1.要完成一個(gè)簡(jiǎn)單的三子棋程序,首先需要?jiǎng)?chuàng)建一個(gè)二維數(shù)組,并完成數(shù)組初始化。
//使用宏定義定義常量,方便之后對(duì)數(shù)組的使用 #define ROW 3 //行 #define COL 3 //列 char arr[ROW][COL] = { 0 }; Arr_init(arr, ROW, COL); //數(shù)組初始化
2.完成數(shù)組的初始化后,我們需要將三子棋所需要的棋盤打印出來。
void Print_che(char arr[ROW][COL], int row, int col) //打印棋盤 { int i, j; for(i = 0; i < row; i++) { for(j = 0; j < col; j++) { printf(" %c ", arr[i][j]); if (j < col - 1) printf("|"); } printf("\n"); for(j = 0; j < col ; j++) { if (i < row - 1) printf("___"); else printf(" "); if (j < col - 1) printf("|"); } printf("\n"); } }
3.打印完棋盤后,我們就要開始下棋了,為了增加游戲的難度,我們讓電腦先走,電腦走的字符為'0'。
void Computer_walk(char arr[ROW][COL], int row, int col) //電腦走 { int x, y; printf("請(qǐng)電腦輸入坐標(biāo)\n"); while(1) { x = rand() % row; //生成隨機(jī)數(shù) y = rand() % col; if (arr[x][y] == ' ') //判斷坐標(biāo)正確性 { arr[x][y] = '0'; break; } } }
4.電腦走完后,輪到玩家走,玩家走的字符為'X'。
void Player_go(char arr[ROW][COL], int row, int col) //玩家走 { int x, y; printf("請(qǐng)玩家輸入坐標(biāo):"); while (1) { scanf("%d %d", &x, &y); if ((x > 0 && x <= row + 1) && (y > 0 && y <= col + 1)) //判斷坐標(biāo)正確性 { if (arr[x - 1][y - 1] == ' ') { arr[x - 1][y - 1] = 'X'; break; } else printf("輸入錯(cuò)誤,請(qǐng)重新輸入:"); } else printf("輸入錯(cuò)誤,請(qǐng)重新輸入:"); } }
5.電腦和玩家每走一次,都需要判斷一次輸贏。
char Judge_win(char arr[ROW][COL], int row, int col) //判斷輸贏 { int i, j; int count = 0; for (i = 0; i < row; i++) { if (arr[i][0] == arr[i][1] && arr[i][1] == arr[i][2] && arr[i][0] != ' ') //行相等 return arr[i][1]; if (arr[0][i] == arr[1][i] && arr[1][i] == arr[2][i] && arr[0][i] != ' ') //列相等 return arr[1][i]; if (arr[0][0] == arr[1][1] && arr[1][1] == arr[2][2] && arr[1][1] != ' ') //正斜相等 return arr[1][1]; if (arr[0][2] == arr[1][1] && arr[1][1] == arr[2][0] && arr[1][1] != ' ') //反斜相等 return arr[1][1]; } for (i = 0; i < row; i++)//平局 { for (j = 0; j < col; j++) { if (arr[i][j] == 'X' || arr[i][j] == '0') //遍歷數(shù)組,查看是否還有沒有走的地方 { count++; if (count == 9) return 'Q'; } } } return 'A'; }
確定大致思路后,我們完成程序的流程部分,放入我們所創(chuàng)建的文件中。
代碼如下:
game.h //包含函數(shù)的聲明,宏定義
#ifndef _GAME_H__ #define _GAME_H__ #include <stdio.h> #include <windows.h> #include <stdlib.h> #include <time.h> #define ROW 3 //行 #define COL 3 //列 void Arr_init(char arr[ROW][COL], int row, int col); //數(shù)組初始化 void Print_che(char arr[ROW][COL], int row, int col);//打印棋盤 void Player_go(char arr[ROW][COL], int row, int col);//玩家走 void Computer_walk(char arr[ROW][COL], int row, int col);//電腦走 char Judge_win(char arr[ROW][COL], int row, int col);//判斷輸贏 #endif // GAME_H__ test.c //包含主函數(shù),函數(shù)調(diào)用 #define _CRT_SECURE_NO_WARNINGS 1 #include "game.h" void menu() //菜單函數(shù) { printf("********************\n"); printf("**** 1.play ****\n"); printf("**** 0.exit ****\n"); printf("********************\n"); } void game() //游戲函數(shù) { char arr[ROW][COL] = { 0 }; Arr_init(arr, ROW, COL); //數(shù)組初始化 Print_che(arr, ROW, COL); //打印棋盤 while(1) { char n; Computer_walk(arr, ROW, COL); //電腦走 Print_che(arr, ROW, COL); n = Judge_win(arr, ROW, COL); //判斷輸贏 if (n == 'X') //根據(jù)判斷輸贏函數(shù)所返回的值做出不同的選擇 { printf("玩家贏\n"); break; } else if (n == '0') { printf("電腦贏\n"); break; } else if (n == 'Q') { printf("平局\n"); break; } else printf("----------------\n"); Player_go(arr, ROW, COL);//玩家走 Print_che(arr, ROW, COL); n = Judge_win(arr, ROW, COL);//判斷輸贏 if (n == 'X') { printf("玩家贏\n"); break; } else if (n == '0') { printf("電腦贏\n"); break; } else if (n == 'Q') printf("平局\n"); else printf("------------------\n"); } } void test() //游戲流程函數(shù) { int input = 0; srand((unsigned)time(NULL)); do { menu(); printf("請(qǐng)輸入選擇:"); scanf("%d", &input); switch (input) { case 1: game(); break; case 0: break; default: printf("輸入錯(cuò)誤,請(qǐng)重新輸入。\n"); } } while (input); } int main() { test(); system("pause"); return 0; }
game.c //包含函數(shù)的定義
#include "game.h" void Arr_init(char arr[ROW][COL], int row, int col)//數(shù)組初始化 { int i = 0; int j = 0; for(i = 0; i < row; i++) { for(j = 0; j < col; j++) arr[i][j] = ' '; } } void Print_che(char arr[ROW][COL], int row, int col)//打印棋盤 { int i, j; for(i = 0; i < row; i++) { for(j = 0; j < col; j++) { printf(" %c ", arr[i][j]); if (j < col - 1) printf("|"); } printf("\n"); for(j = 0; j < col ; j++) { if (i < row - 1) printf("___"); else printf(" "); if (j < col - 1) printf("|"); } printf("\n"); } } void Player_go(char arr[ROW][COL], int row, int col) //玩家走 { int x, y; printf("請(qǐng)玩家輸入坐標(biāo):"); while (1) { scanf("%d %d", &x, &y); if ((x > 0 && x <= row + 1) && (y > 0 && y <= col + 1)) //判斷坐標(biāo)正確性 { if (arr[x - 1][y - 1] == ' ') { arr[x - 1][y - 1] = 'X'; break; } else printf("輸入錯(cuò)誤,請(qǐng)重新輸入:"); } else printf("輸入錯(cuò)誤,請(qǐng)重新輸入:"); } } void Computer_walk(char arr[ROW][COL], int row, int col) //電腦走 { int x, y; printf("請(qǐng)電腦輸入坐標(biāo)\n"); while(1) { x = rand() % row; //生成隨機(jī)數(shù) y = rand() % col; if (arr[x][y] == ' ') //判斷坐標(biāo)正確性 { arr[x][y] = '0'; break; } } } char Judge_win(char arr[ROW][COL], int row, int col) //判斷輸贏 { int i, j; int count = 0; for (i = 0; i < row; i++) { if (arr[i][0] == arr[i][1] && arr[i][1] == arr[i][2] && arr[i][0] != ' ') //行相等 return arr[i][1]; if (arr[0][i] == arr[1][i] && arr[1][i] == arr[2][i] && arr[0][i] != ' ') //列相等 return arr[1][i]; if (arr[0][0] == arr[1][1] && arr[1][1] == arr[2][2] && arr[1][1] != ' ') //正斜相等 return arr[1][1]; if (arr[0][2] == arr[1][1] && arr[1][1] == arr[2][0] && arr[1][1] != ' ') //反斜相等 return arr[1][1]; } for (i = 0; i < row; i++)//平局 { for (j = 0; j < col; j++) { if (arr[i][j] == 'X' || arr[i][j] == '0') //遍歷數(shù)組,查看是否還有沒有走的地方 { count++; if (count == 9) return 'Q'; } } } return 'A'; }
到這里,我們的程序已經(jīng)完成了,我們看看程序的效果
以上就是一個(gè)簡(jiǎn)單的三子棋程序,多有不足之處,還望指教。
更多有趣的經(jīng)典小游戲?qū)崿F(xiàn)專題,分享給大家:
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
C語(yǔ)言中關(guān)于動(dòng)態(tài)內(nèi)存分配的詳解
動(dòng)態(tài)內(nèi)存是指在堆上分配的內(nèi)存,而靜態(tài)內(nèi)存是指在棧上分配的內(nèi)存。棧上分配的內(nèi)存是由系統(tǒng)分配和釋放的,空間有限,在復(fù)合語(yǔ)句或函數(shù)運(yùn)行結(jié)束后就會(huì)被系統(tǒng)自動(dòng)釋放而堆上分配的內(nèi)存則不會(huì)有這個(gè)問題。2021-09-09C語(yǔ)言實(shí)現(xiàn)點(diǎn)菜系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言實(shí)現(xiàn)點(diǎn)菜系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-06-06C語(yǔ)言對(duì)組文件處理的相關(guān)函數(shù)小結(jié)
這篇文章主要介紹了C語(yǔ)言對(duì)組文件處理的相關(guān)函數(shù)小結(jié),包括setgrent()函數(shù)和getgrent()函數(shù)以及endgrent()函數(shù),需要的朋友可以參考下2015-08-08Qt使用QChart實(shí)現(xiàn)靜態(tài)顯示溫度變化曲線
QChart模塊是Qt?Charts庫(kù)的基礎(chǔ),提供了用于創(chuàng)建和顯示各種類型圖表的類和接口,本文主要介紹了如何使用QChart實(shí)現(xiàn)動(dòng)態(tài)顯示3個(gè)設(shè)備的溫度變化曲線,感興趣的可以了解一下2023-06-06C語(yǔ)言?struct結(jié)構(gòu)體超詳細(xì)講解
C語(yǔ)言中,結(jié)構(gòu)體類型屬于一種構(gòu)造類型(其他的構(gòu)造類型還有:數(shù)組類型,聯(lián)合類型),下面這篇文章主要給大家介紹了關(guān)于C語(yǔ)言結(jié)構(gòu)體(struct)的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-04-04C 創(chuàng)建鏈表并將信息存儲(chǔ)在二進(jìn)制文件中讀取的實(shí)例代碼
C 創(chuàng)建鏈表并將信息存儲(chǔ)在二進(jìn)制文件中讀取的實(shí)例代碼,需要的朋友可以參考一下2013-03-03舉例講解C語(yǔ)言的fork()函數(shù)創(chuàng)建子進(jìn)程的用法
fork函數(shù)是Linux下一個(gè)近乎專有的C語(yǔ)言函數(shù),因?yàn)槭褂脮r(shí)需要調(diào)用unistd.h這個(gè)頭文件,這里我們就在Linux環(huán)境下舉例講解C語(yǔ)言的fork()函數(shù)創(chuàng)建子進(jìn)程的用法,需要的朋友可以參考下2016-06-06C++實(shí)現(xiàn)紅黑樹應(yīng)用實(shí)例代碼
紅黑樹它一種特殊的二叉查找樹,這意味著它滿足二叉查找樹的特征,但是也有許多自己的特性,這篇文章主要給大家介紹了關(guān)于C++實(shí)現(xiàn)紅黑樹的相關(guān)資料,需要的朋友可以參考下2021-11-11C++實(shí)現(xiàn)幸運(yùn)大抽獎(jiǎng)(QT版)
這篇文章主要為大家詳細(xì)介紹了C++實(shí)現(xiàn)幸運(yùn)大抽獎(jiǎng),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-01-01