C語(yǔ)言實(shí)現(xiàn)三子棋源代碼
本文實(shí)例為大家分享了C語(yǔ)言實(shí)現(xiàn)三子棋的具體代碼,供大家參考,具體內(nèi)容如下
效果如下:
代碼實(shí)現(xiàn):
頭文件部分
#pragma once #include <stdio.h> #include <stdlib.h> #include <time.h> #define ROW 3 #define COL 3 //函數(shù)聲明 void Initboard(char board[ROW][COL], int row, int col); void Displayboard(char board[ROW][COL], int row, int col); Player(char board[ROW][COL], int row, int col); Computer(char board[ROW][COL], int row, int col); char Judge(char board[ROW][COL], int row, int col);
函數(shù)部分
#include "game.h" void Initboard(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++) board[i][j] = ' '; } //棋盤(pán) // x | x | x //---|---|--- // x | x | x //---|---|--- // x | x | x void Displayboard(char board[ROW][COL], int row, int col) { int i = 0; int j = 0; for (i = 0; i < row; i++) { //打印一行數(shù)據(jù) 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"); } } Player(char board[ROW][COL], int row, int col) { while (1) { int x = 0; int y = 0; printf("請(qǐng)輸入你的棋子坐標(biāo)(如第一行第一列為1 1):\n"); scanf("%d%d", &x, &y); if (x <= row && x >= 1 && y <= col && y >= 1) { if (board[x - 1][y - 1] == ' ') { board[x - 1][y - 1] = '*'; break; } else { printf("該處已有棋子,請(qǐng)重新輸入\n"); continue; } } else printf("坐標(biāo)范圍錯(cuò)誤,請(qǐng)重新輸入"); } } Computer(char board[ROW][COL], int row, int col) { int x = 0; int y = 0; while (1) { x = rand() % ROW; y = rand() % COL; if (board[x][y] == ' ') { board[x][y] = '#'; break; } } } int IsFull(char board[ROW][COL], int row, int col)//返回1表示棋盤(pán)已滿(mǎn),0表示棋盤(pán)沒(méi)滿(mǎn) { int i, j; for (i = 0; i < row; i++) { for (j = 0; j < col; j++) if (board[i][j] == ' ') return 0; } return 1; } char Judge(char board[ROW][COL], int row,int col) { int i = 0; //行有三個(gè)相連的情況 for (i = 0; i < row; i++) { if (board[i][0] == board[i][1] && board[i][1]== board[i][2] && board[i][0] != ' ') return board[i][0]; } //列有三個(gè)相連的情況 for (i = 0; i < col; i++) { if (board[0][i] == board[1][i] && board[1][i]== board[2][i] && board[0][i] != ' ') return board[0][i]; } //對(duì)角線(xiàn)三個(gè)相連的情況 if (board[0][0] == board[1][1]&& board[1][1]==board[2][2]&&board[0][0]!=' ' || board[0][2] == board[1][1]&&board[1][1] == board[2][0]&&board[0][2] != ' ') return board[1][1]; //平局的情況(棋盤(pán)滿(mǎn)了) if (IsFull( board , ROW,COL) ==1) { return 'E'; } return 'C'; }
主函數(shù)部分
#include "game.h" void menu() { printf("***************************\n"); printf("***1.開(kāi)始游戲 0.退出游戲***\n"); printf("***************************\n"); printf("請(qǐng)輸入數(shù)字1或0:"); } void game() { char r; char board[ROW][COL] = { 0 }; //初始化棋盤(pán)(清空棋盤(pán)) Initboard(board, ROW, COL); //打印棋盤(pán) Displayboard(board, ROW, COL); //人機(jī)對(duì)弈 while (1) { Player(board, ROW, COL); Displayboard(board, ROW, COL); r = Judge(board, ROW, COL); if (r != 'C') break; Computer(board, ROW, COL); Displayboard(board, ROW, COL); r = Judge(board, ROW, COL); if (r != 'C') break; } //判斷輸贏(yíng) if (r == '*') { printf("玩家贏(yíng)\n"); } else if (r == '#') { printf("電腦贏(yíng)\n"); } else if (r == 'E') { printf("平局\n"); } } int main() { srand((unsigned int)time(NULL)); int input = 0; do { menu(); scanf("%d", &input); switch (input) { case 1: printf("開(kāi)始游戲\n"); game(); break; case 0: printf("退出游戲\n"); break; default: printf("請(qǐng)輸入正確的選項(xiàng)\n"); break; } } while (input); printf("游戲結(jié)束!"); return 0; }
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
C語(yǔ)言實(shí)現(xiàn)猜數(shù)字大小的游戲
這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言實(shí)現(xiàn)猜數(shù)字大小的游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-01-01C語(yǔ)言超詳細(xì)分析多進(jìn)程的概念與使用
在一個(gè)項(xiàng)目中并發(fā)執(zhí)行任務(wù)時(shí)多數(shù)情況下都會(huì)選擇多線(xiàn)程,但有時(shí)候也會(huì)選擇多進(jìn)程,例如可以同時(shí)運(yùn)行n個(gè)記事本編輯不同文本,由一個(gè)命令跳轉(zhuǎn)到另外一個(gè)命令,或者使用不同進(jìn)程進(jìn)行協(xié)作2022-08-08C++模擬實(shí)現(xiàn)vector示例代碼圖文講解
這篇文章主要介紹了C++容器Vector的模擬實(shí)現(xiàn),Vector是一個(gè)能夠存放任意類(lèi)型的動(dòng)態(tài)數(shù)組,有點(diǎn)類(lèi)似數(shù)組,是一個(gè)連續(xù)地址空間,下文更多詳細(xì)內(nèi)容的介紹,需要的小伙伴可以參考一下2023-02-02C++實(shí)現(xiàn)LeetCode(111.二叉樹(shù)的最小深度)
這篇文章主要介紹了C++實(shí)現(xiàn)LeetCode(111.二叉樹(shù)的最小深度),本篇文章通過(guò)簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-07-07C++標(biāo)準(zhǔn)庫(kù)學(xué)習(xí)之weak_ptr智能指針用法詳解
這篇文章主要為大家詳細(xì)介紹了C++標(biāo)準(zhǔn)庫(kù)中weak_ptr智能指針用法的相關(guān)知識(shí),文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2023-12-12C語(yǔ)言實(shí)戰(zhàn)之浪漫煙花表白程序代碼
這篇文章主要介紹了C語(yǔ)言實(shí)戰(zhàn)之浪漫煙花表白程序代碼,需要的朋友可以參考下2021-04-04