用C語言實現(xiàn)簡單五子棋小游戲
更新時間:2021年07月30日 11:24:27 作者:Stout800
這篇文章主要為大家詳細介紹了用C語言實現(xiàn)簡單五子棋小游戲,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
本文實例為大家分享了C語言實現(xiàn)簡單五子棋小游戲的具體代碼,供大家參考,具體內(nèi)容如下
在vs2019創(chuàng)建新項目,然后添加兩個源文件test.c和game.c,接著創(chuàng)建一個頭文件game.h。
test.c:
#include "game.h" void game() { char board[ROW][COL]; InitBoard(board, ROW, COL); DisplayBoard(board, ROW, COL); char ret = 0; while (1) { PlayerMove(board, ROW, COL); DisplayBoard(board, ROW, COL); ret = IsWin(board, ROW, COL); if (ret != 'C') { break; } ComputerMove(board, ROW, COL); DisplayBoard(board, ROW, COL); ret = IsWin(board, ROW, COL); if (ret != 'C') { break; } } if (ret == '*') { printf("玩家贏\n"); } else if (ret == '#') { printf("電腦贏\n"); } else { printf("平局\n"); } } void menu() { printf("******************************\n"); printf("******* 1.play ******\n"); printf("******* 0.exit ******\n"); printf("******************************\n"); } int main() { int input = 0; srand((unsigned int)time(NULL)); do { menu(); printf("請輸入:\n"); scanf("%d", &input); switch (input) { case 1: game(); break; case 0: printf("退出游戲\n"); break; default: printf("輸入錯誤,請重新輸入:\n"); break; } } while (input); return 0; }
game.c:
#include "game.h" void InitBoard(char board[ROW][COL], int row, int col) { int i = 0; for (i = 0; i < row; i++) { int j = 0; for (j = 0; j < col; j++) { board[i][j] = ' '; } } } void DisplayBoard(char board[ROW][COL], int row, int col) { int i = 0; for (i = 0; i < row; i++) { int j = 0; for (j = 0; j < col; j++) { printf(" %c ",board[i][j]); if (j < col - 1) { printf("|"); } } printf("\n"); if (i < row - 1) { for (j = 0; j < col; j++) { printf("---"); if (j < col - 1) printf("|"); } } printf("\n"); } } void PlayerMove(char board[ROW][COL], int row, int col) { printf("玩家走:\n"); int i = 0; int j = 0; while (1) { printf("請輸入坐標:\n"); scanf("%d%d", &i, &j); if (i >= 1 && i <= row && j >= 1 && j <= col) { if (board[i - 1][j - 1] == ' ') { board[i - 1][j - 1] = '*'; break; } else { printf("坐標被占用,請重新輸入\n"); } } else { printf("坐標超出范圍\n"); } } } void ComputerMove(char board[ROW][COL], int row, int col) { int i = 0; int j = 0; printf("電腦走:\n"); while (1) { i = rand() % row; j = rand() % col; if (board[i][j] == ' ') { board[i][j] = '#'; break; } } } int IsFull(char board[ROW][COL], int row, int col) { int i = 0; int j = 0; for (i = 0; i < row; i++) { for (j = 0; j < col; j++) { if (board[i][j] == ' ') { return 0;//棋盤沒滿 } } } return 1;//棋盤滿了 } char IsWin(char board[ROW][COL], int row, int col) { int i = 0; //判斷三行 for (i = 0; i < row; i++) { if (board[i][0] == board[i][1] && board[i][1] == board[i][2] && board[i][1] != ' ') { return board[i][1];// } } //判斷三列 for (i = 0; i < col; i++) { if (board[0][i] == board[1][i] && board[1][i] == board[2][i] && board[1][i] != ' ') { return board[1][i]; } } //判斷對角線 if (board[0][0] == board[1][1] && board[1][1] == board[2][2] && board[1][1] != ' ') { return board[1][1]; } if (board[0][2] == board[1][1] && board[1][1] == board[2][0] && board[1][1] != ' ') { return board[1][1]; } //判斷平局 //如果棋盤滿了返回1, 不滿返回0 int ret = IsFull(board, row, col); if (ret == 1) { return 'Q'; } //繼續(xù) return 'C'; }
game.h:
#include <stdio.h> #include <stdlib.h> #include <time.h> #define ROW 3 #define COL 3 void InitBoard(char board[ROW][COL], int row, int col); void DisplayBoard(char board[ROW][COL], int row, int col); void PlayerMove(char board[ROW][COL], int row, int col); void ComputerMove(char board[ROW][COL], int row, int col); char IsWin(char board[ROW][COL], int row, int col); int IsFull(char board[ROW][COL], int row, int col);
運行效果如圖:
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
C++數(shù)據(jù)結(jié)構(gòu)之list詳解
list是一種序列式容器。list容器完成的功能實際上和數(shù)據(jù)結(jié)構(gòu)中的雙向鏈表是極其相似的,list中的數(shù)據(jù)元素是通過鏈表指針串連成邏輯意義上的線性表,也就是list也具有鏈表的主要優(yōu)點,即:在鏈表的任一位置進行元素的插入、刪除操作都是快速的2021-11-11C/C++如何實現(xiàn)循環(huán)左移,循環(huán)右移
這篇文章主要介紹了C/C++如何實現(xiàn)循環(huán)左移,循環(huán)右移,具有很好的參考價值,希望對大家有所幫助。具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-07-07C++ 字符串string和整數(shù)int的互相轉(zhuǎn)化操作
這篇文章主要介紹了C++ 字符串string和整數(shù)int的互相轉(zhuǎn)化操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-12-12大家注意vector, list, set, map成員函數(shù)erase
set和map是由紅黑樹來實現(xiàn)的,當erase的時候迭代器就失效了,也就是說我們要在迭代器失效之前保留一個副本,根據(jù)這個副本我們才能繼續(xù)遍歷下一個元素2013-09-09