欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C語言實現(xiàn)簡單的三子棋游戲源碼

 更新時間:2022年01月05日 08:39:26   作者:Jiawen_captial  
這篇文章主要為大家詳細(xì)介紹了C語言實現(xiàn)簡單的三子棋游戲源碼,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下

本文實例為大家分享了C語言實現(xiàn)簡單的三子棋游戲的具體代碼,供大家參考,具體內(nèi)容如下

1、游戲的整體劃分

因為C語言是面向過程的,我將游戲抽象出來玩家下棋,電腦下棋,在判斷輸贏這一過程,又通過對過程的分析,進(jìn)行了具體函數(shù)的實現(xiàn),分為如下模塊:

游戲主菜單函數(shù)

void menu();

初始化棋盤函數(shù)

void InitBoard(char board[ROW][COL], int row, int col);

打印棋盤函數(shù)

void DisplayBoard(char board[ROW][COL], int row, int col);

玩家下棋函數(shù)

void PlayerMove(char board[ROW][COL], int row, int col);

電腦下棋函數(shù)

void ComputerMove(char board[ROW][COL], int row, int col);

判斷棋盤是否為空的函數(shù)

int IsFull(char board[ROW][COL], int row, int col);

判斷輸贏的函數(shù)

char IsWin(char board[ROW][COL], int row, int col);
//.h文件的源碼,僅供大家參考
#pragma once
#include <stdio.h>
#include <stdlib.h>
#include <time.h>

#define ROW 3
#define COL 3
void menu();
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);
int IsFull(char board[ROW][COL], int row, int col);
char IsWin(char board[ROW][COL], int row, int col);

2、整體講解及其菜單函數(shù)實現(xiàn)

在對于棋盤方面,利用#define定義了一個大小為3行3列的char類型的數(shù)組,來表示整個的棋盤。整體游戲邏輯的實現(xiàn)使用do……while();循環(huán)和switch多分支語句的配合使用,使得完成整個游戲的邏輯過程。

菜單menu函數(shù)的實現(xiàn)是要配合switch語句來進(jìn)行的,以便后期對switch語句進(jìn)行操作,menu函數(shù)具體實現(xiàn)如下:

void menu()
{
?? ?printf("************歡迎來到三子棋游戲中心**************\n");
?? ?printf("************1.開始游戲 ? ? ? ? ? ?**************\n");
?? ?printf("************2.再來一局 ? ? ? ? ? ?**************\n");
?? ?printf("************0.退出游戲 ? ? ? ? ? ?**************\n");
}

3、初始化棋盤和打印棋盤

1.初始化棋盤

利用函數(shù)將數(shù)組傳遞過來,對二維數(shù)組進(jìn)行遍歷賦值為空字符,從而完成對整個數(shù)組的初始化。具體代碼如下:

void InitBoard(char board[ROW][COL], int row, int col)
{
?? ?for (int i = 0; i < row; i++)
?? ?{
?? ??? ?for (int j = 0; j < col; j++)
?? ??? ?{
?? ??? ??? ?board[i][j] = ' ';
?? ??? ?}
?? ?}
}

2.打印棋盤

打印棋盤時數(shù)組的遍歷要配合條件控制下的字符的打印結(jié)合,從而使打印的棋盤不僅僅是單純不變的數(shù)組,是棋盤被|和-分割開,更加的形象。具體實現(xiàn)如下:

void DisplayBoard(char board[ROW][COL], int row, int col)
{
?? ?for (int i = 0; i < row; i++)
?? ?{
?? ??? ?for (int j = 0; j < col; j++)
?? ??? ?{
?? ??? ??? ?printf("%c", board[i][j]);
?? ??? ??? ?if (0 == j || 1 == j)
?? ??? ??? ?{
?? ??? ??? ??? ?printf("|");
?? ??? ??? ?}
?? ??? ?}
?? ??? ?printf("\n");
?? ??? ?for (int k = 0; k < col; k++)
?? ??? ?{
?? ??? ??? ?if (0 == i || 1 == i)
?? ??? ??? ?{
?? ??? ??? ??? ?printf("--");
?? ??? ??? ?}
?? ??? ?}
?? ??? ?printf("\n");
?? ?}
}

4、玩家下棋和電腦下棋

1.玩家下棋

玩家下棋時,定義了兩個整型的變量,用來充當(dāng)數(shù)組的下標(biāo)。當(dāng)玩家輸入數(shù)組的下標(biāo)位置在合適的范圍的時候,在當(dāng)前下標(biāo)賦值了字符‘*’來代表玩家的下棋。并且下棋成功后,將棋盤的情況打印出來,便于玩家了解當(dāng)前游戲的局勢和情況。具體實現(xiàn)如下:

void PlayerMove(char board[ROW][COL], int row, int col)
{
?? ?int r = 0, c = 0;
?? ?printf("請輸入您要下棋的位置:\n");
?? ?while (1)
?? ?{
?? ??? ?scanf("%d %d", &r, &c);
?? ??? ?r = r - 1;
?? ??? ?c = c - 1;
?? ??? ?if (board[r][c]==' ')
?? ??? ?{
?? ??? ??? ?board[r][c] = '*';
?? ??? ??? ?printf("下棋成功\n");
?? ??? ??? ?DisplayBoard(board, ROW, COL);
?? ??? ??? ?break;
?? ??? ?}
?? ??? ?else
?? ??? ?{
?? ??? ??? ?printf("輸入的位置有誤或已被占用,請重新輸入:\n");
?? ??? ?}
?? ?}
}

2.電腦下棋

電腦下棋時原來同玩家一樣,區(qū)別在于電腦用的不是直接從鍵盤輸入的值,而是利用rand函數(shù)隨機生成的值,具體實現(xiàn)如下

void ComputerMove(char board[ROW][COL], int row, int col)
{
?? ?int r = 0, c = 0;
?? ?printf("電腦走>\n");
?? ?while (1)
?? ?{
?? ??? ?r = rand() % row;
?? ??? ?c = rand() % col;
?? ??? ?if (board[r][c] == ' ')
?? ??? ?{
?? ??? ??? ?board[r][c] = '#';
?? ??? ??? ?DisplayBoard(board, ROW, COL);
?? ??? ??? ?break;
?? ??? ?}
?? ?}
}

5、判斷輸贏

當(dāng)棋盤中橫、豎或者對角線的值相等的時候就可分出勝負(fù),如果棋盤已經(jīng)被下滿并且沒有分出勝負(fù),那就是平局。采用比較暴力遍歷比較,返回4種不同的狀態(tài):
1、玩家贏 - ‘*’
2、電腦贏 - ‘#’
3、平局 - ‘Q’
4、繼續(xù) - ‘C’
具體實現(xiàn)如下:

char IsWin(char board[ROW][COL], int row, int col)
{
?? ?int i = 0;
?? ?for (int 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 (int i = 0; i < i; 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];
?? ?}
?? ?int ret = IsFull(board, row, col);
?? ?if (ret == 1)
?? ?{
?? ??? ?return 'Q';
?? ?}
?? ?return 'C';
}

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • C++數(shù)據(jù)結(jié)構(gòu)AVL樹全面分析

    C++數(shù)據(jù)結(jié)構(gòu)AVL樹全面分析

    今天的這一篇博客,我要跟大家介紹一顆樹——AVL樹,它也是一顆二叉搜索樹,它就是在二叉搜索樹中加了一個平衡因子的概念在里面,下面我就來和大家聊一聊這棵樹是個怎么樣的樹
    2021-10-10
  • C++ vector類的模擬實現(xiàn)方法

    C++ vector類的模擬實現(xiàn)方法

    這篇文章主要介紹了C++ vector類的模擬實現(xiàn)方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-05-05
  • C語言實現(xiàn)電話簿管理系統(tǒng)

    C語言實現(xiàn)電話簿管理系統(tǒng)

    這篇文章主要為大家詳細(xì)介紹了C語言實現(xiàn)電話簿管理系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-12-12
  • Qt實現(xiàn)UI界面純代碼示例

    Qt實現(xiàn)UI界面純代碼示例

    這篇文章主要給大家介紹了關(guān)于Qt實現(xiàn)UI界面的相關(guān)資料,使用Qt純代碼,實現(xiàn)了基本的界面,對大家學(xué)習(xí)或者使用Qt具有一定的參考借鑒價值,需要的朋友可以參考下
    2024-01-01
  • C語言中反斜杠的作用及說明

    C語言中反斜杠的作用及說明

    這篇文章主要介紹了C語言中反斜杠的作用及說明,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-07-07
  • JetBrains?CLion永久激活超詳細(xì)教程(最新激活方法)

    JetBrains?CLion永久激活超詳細(xì)教程(最新激活方法)

    JetBrains?Clion?是一款專為?C/C++?開發(fā)所設(shè)計的跨平臺?IDE,本文適用?JetBrains?CLion?v2019.3/3.1/3.2/3.3?永久激活,附破解補丁和激活碼,可以永久激活?Windows、MAC、Linux?下的?CLion,下面給大家分享JetBrains?CLion永久激活超詳細(xì)教程,感興趣的朋友一起看看吧
    2023-01-01
  • C++實現(xiàn)LeetCode(66.加一運算)

    C++實現(xiàn)LeetCode(66.加一運算)

    這篇文章主要介紹了C++實現(xiàn)LeetCode(66.加一運算),本篇文章通過簡要的案例,講解了該項技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下
    2021-07-07
  • c++實現(xiàn)二路歸并排序的示例代碼

    c++實現(xiàn)二路歸并排序的示例代碼

    這篇文章主要介紹了c++實現(xiàn)二路歸并排序的示例代碼,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-04-04
  • 詳解C++設(shè)計模式編程中建造者模式的實現(xiàn)

    詳解C++設(shè)計模式編程中建造者模式的實現(xiàn)

    這篇文章主要介紹了C++設(shè)計模式編程中建造者模式的實現(xiàn),建造者模式將一個復(fù)雜對象的構(gòu)建于它的表現(xiàn)分離,可以減少代碼冗余,需要的朋友可以參考下
    2016-03-03
  • C語言對磁盤文件進(jìn)行快速排序簡單實例

    C語言對磁盤文件進(jìn)行快速排序簡單實例

    這篇文章主要介紹了C語言對磁盤文件進(jìn)行快速排序簡單實例的相關(guān)資料,需要的朋友可以參考下
    2017-06-06

最新評論