亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

利用C語言實現(xiàn)三子棋游戲

 更新時間:2021年02月23日 15:06:22   作者:yuelinghou  
這篇文章主要為大家詳細介紹了利用C語言實現(xiàn)三子棋游戲,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下

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

說明:該游戲的實現(xiàn)需要用到三個文件

1、test.c:放置主函數(shù)(main())和菜單函數(shù)(menu())和游戲函數(shù)(game())。
2、game.c:放置game()里面的相應(yīng)操作的函數(shù),例如玩家移動(PlayerMove(board)),電腦移動(ComputerMove(board)),以及每一次移動之后打印當(dāng)前棋盤內(nèi)容的函數(shù)(DisplayBoard(board))等等。由于這些函數(shù)內(nèi)容較多,所以單獨放在一個頭文件里實現(xiàn)。
3、game.h:放置game.c里面函數(shù)的聲明,以及需要用到的庫函數(shù)的頭文件(stdio.h,stdlib.h,time.h),在test.c和game.c中引用即可(#include " game.h ")

test.c

1.主函數(shù)(main () )

游戲的大體執(zhí)行流程

int main()
{
 //設(shè)置隨機數(shù)生成起點,作為后面電腦下子時的坐標(biāo)
 srand((unsigned int)time(NULL));
 int input = 0;
 do
 {
 menu();//菜單函數(shù)
 printf("請選擇:>");
 scanf("%d", &input);
 switch (input)
 {
 case 1:
 game();
 break;
 case 0:
 printf("退出游戲\n");
 break;
 default:
 printf("選擇錯誤,請重新選擇\n");
 break;
 }
 } while (input);
 return 0;
}

2.菜單函數(shù)(menu())

玩家選擇玩游戲或者退出

void menu()
{
 printf("***************************************\n");
 printf("*** 1.play    0.exit ***\n");
 printf("***************************************\n");
}

3.游戲函數(shù)(game () )

三子棋游戲的操作步驟,里面涉及到的函數(shù)會在game.c說明

void game()
{
 //作為標(biāo)志判斷最后結(jié)果的標(biāo)志
 int ret = 0;
 //設(shè)置存放棋盤信息的數(shù)組
 char board[3][3] = { 0 };
 //初始化棋盤內(nèi)容全部為空格
 InitBoard(board);
 //打印棋盤
 DisplayBoard(board);
 //下棋
 //下棋過程
 while (1)
 {
 //玩家下子
 PlayerMove(board);
 DisplayBoard(board);
 ret = IsWin(board);
 //若ret=='c'就繼續(xù)下棋,其他的就是玩家贏或者電腦贏或者平局就停止下棋,跳出while循環(huán)
 if ('c' != ret)
 break;
 //電腦下子
 ComputerMove(board);
 DisplayBoard(board);
 ret = IsWin(board);
 if ('c' != ret)
 break;
 }
 //下棋結(jié)束,判斷誰贏了
 if ('*' == ret)
 printf("玩家贏\n");
 else if ('#' == ret)
 printf("電腦贏\n");
 else if('e'==ret)
 printf("平局\n");
}

game.c

ps:里面的p數(shù)組指針,實參為board,即棋盤第一行數(shù)組的地址

1. InitBoard(初始化棋盤內(nèi)容)

//初始化棋盤內(nèi)容全部為空格
void InitBoard(char (*p)[3])
{
 int i = 0;
 for (i = 0; i < 3; i++)
 {
 int j = 0;
 for (j = 0; j < 3; j++)
 {
 p[i][j] = ' ';
 }
 }
}

2.DisplayBoard(展示棋盤內(nèi)容)

開始時的棋盤是這樣的

void DisplayBoard(char (*p)[3])
{
 int i = 0;
 //棋盤每行的打印
 for (i = 0; i < 3; i++)
 {
 //打印棋子和豎桿
 printf(" %c | %c | %c \n", p[i][0], p[i][1], p[i][2]);
 //分隔行只用打印兩行
 if (i < 2)
 printf("---|---|---\n");
 }
}

3.PlayerMove(玩家下子)

玩家下的子用*表示,需要注意兩點1.下的子是否在棋盤坐標(biāo)內(nèi) 2.該坐標(biāo)是否已經(jīng)被下子。

//玩家下子(*)
void PlayerMove(char (*p)[3])
{
 int x = 0;
 int y = 0;
 printf("玩家走:>\n");
 while (1)
 {
 printf("請輸入要下的坐標(biāo)(有空格隔開):>");
 scanf("%d%d", &x, &y);
 //判斷坐標(biāo)是否正確
 if (x >= 1 && x <= 3 && y >= 1 && y <= 3)
 {
 //若下子坐標(biāo)正確,再判斷該坐標(biāo)是否已經(jīng)被下子
 if (p[x-1][y-1]==' ')
 {
 p[x-1][y-1] = '*';
 break;
 }
 else
 {
 printf("該位置已經(jīng)被下子\n");
 }
 }
 else
 {
 printf("坐標(biāo)輸入錯誤\n");
 }
 }
}

4.ComputerMove(電腦下子)

電腦下的子用#表示,通過限定rand函數(shù)得到的下子坐標(biāo)肯定是在棋盤內(nèi)了,只需考慮該坐標(biāo)是否已經(jīng)被下子。

//電腦下子(#)
void ComputerMove(char (*p)[3])
{
 int x = 0;
 int y = 0;
 printf("電腦走:>\n");
 //下子坐標(biāo)已經(jīng)有效,只需判斷該坐標(biāo)是否已經(jīng)被下子
 while (1)
 {
 //令x和y隨機生成一個0-2之間的數(shù)來作為電腦下子的坐標(biāo)
 int x = rand() % 3;
 int y = rand() % 3;
 //判斷是否已經(jīng)被下子
 if (' ' == p[x][y])
 {
 p[x][y] = '#';
 break;
 }
 }
}

5.IsWin(判斷輸贏)和IsFull(判斷棋盤是否已經(jīng)被下滿)

每下一步棋都有四種情況,玩家贏,電腦贏,平局,繼續(xù),通過IsWin來判斷:

  • 判斷誰贏:棋盤三行或者三列或者兩條對角線都是同一種棋子,誰贏了就返回他所下的棋子的符號(*或者#)
  • 要是都沒贏的話只剩兩種情況平局(棋盤下滿了)和繼續(xù)(棋盤沒下滿),通過IsFull來判斷當(dāng)前棋盤是否滿了來決定是否繼續(xù)下棋。
//判斷棋盤是否已經(jīng)下滿
//下滿返回1
//沒下滿返回0
int IsFull(char(*p)[3])
{
 int i = 0;
 int j = 0;
 for (i = 0; i < 3; i++)
 {
 for (j = 0; j < 3; j++)
 {
 if (p[i][j] == ' ')
 return 0;
 }
 }
 return 1;
}

//判斷輸贏
//玩家贏了返回'*'
//電腦贏了返回'#'
//平局返回'e'
//繼續(xù)返回'c'
char IsWin(char(*p)[3])
{
 int i = 0;
 //橫三行
 for (i = 0; i < 3; i++)
 {
 if (p[i][0] == p[i][1] && p[i][1] == p[i][2] && p[i][0] != ' ')
 return p[i][0];
 }
 //豎三列
 for (i = 0; i < 3; i++)
 {
 if (p[0][i] == p[1][i] && p[1][i] == p[2][i] && p[0][i] != ' ')
 return p[0][i];
 }
 //兩個對角線
 if (p[0][0] == p[1][1] && p[1][1] == p[2][2] && p[0][0] != ' ')
 return p[0][0];
 if (p[0][2] == p[1][1] && p[1][1] == p[2][0] && p[0][2] != ' ')
 return p[0][2];
 //判斷平局還是繼續(xù)(電腦和玩家都沒贏。此時棋盤滿了就平局,沒滿就繼續(xù))
 if (IsFull(p))
 return 'e';
 else
 return 'c';
}

game.h

包括函數(shù)的聲明和需要用到的C語言的庫函數(shù)

#include<stdio.h>
#include<stdlib.h>
#include<time.h>

void InitBoard(char (*p)[3]);
void DisplayBoard(char (*p)[3]);
void PlayerMove(char (*p)[3]);
void ComputerMove(char (*p)[3]);
char IsWin(char (*p)[3]);

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

相關(guān)文章

  • C語言實現(xiàn)經(jīng)典windows游戲掃雷的示例代碼

    C語言實現(xiàn)經(jīng)典windows游戲掃雷的示例代碼

    今天我們會用C語言實現(xiàn)一個經(jīng)典的windows小游戲:掃雷。掃雷是一款單機小游戲,每次通關(guān)最高難度的關(guān)卡都會開心好一陣。現(xiàn)在學(xué)會了C語言,總算可以自己實現(xiàn)掃雷了。話不多說,咱們開始吧
    2022-10-10
  • C++使用遞歸和非遞歸算法實現(xiàn)的二叉樹葉子節(jié)點個數(shù)計算方法

    C++使用遞歸和非遞歸算法實現(xiàn)的二叉樹葉子節(jié)點個數(shù)計算方法

    這篇文章主要介紹了C++使用遞歸和非遞歸算法實現(xiàn)的二叉樹葉子節(jié)點個數(shù)計算方法,涉及C++二叉樹的定義、遍歷、統(tǒng)計相關(guān)操作技巧,需要的朋友可以參考下
    2017-05-05
  • C語言實現(xiàn)簡單的五子棋游戲

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

    這篇文章主要為大家詳細介紹了c語言實現(xiàn)簡單的五子棋游戲,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-01-01
  • C語言中數(shù)據(jù)是如何存儲在內(nèi)存中的

    C語言中數(shù)據(jù)是如何存儲在內(nèi)存中的

    使用編程語言進行編程時,需要用到各種變量來存儲各種信息。變量保留的是它所存儲的值的內(nèi)存位置。這意味著,當(dāng)您創(chuàng)建一個變量時,就會在內(nèi)存中保留一些空間。您可能需要存儲各種數(shù)據(jù)類型的信息,操作系統(tǒng)會根據(jù)變量的數(shù)據(jù)類型,來分配內(nèi)存和決定在保留內(nèi)存中存儲什么
    2022-04-04
  • C語言演示對歸并排序算法的優(yōu)化實現(xiàn)

    C語言演示對歸并排序算法的優(yōu)化實現(xiàn)

    這篇文章主要介紹了C語言演示對歸并排序算法的優(yōu)化實現(xiàn),歸并排序的最差時間復(fù)雜度為(n\log n),最優(yōu)時間復(fù)雜為(n),存在可以改進的空間,需要的朋友可以參考下
    2016-05-05
  • C語言實現(xiàn)萬年歷小程序

    C語言實現(xiàn)萬年歷小程序

    這篇文章主要為大家詳細介紹了C語言實現(xiàn)萬年歷小程序,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-10-10
  • C++?Boost?Foreach超詳細分析講解

    C++?Boost?Foreach超詳細分析講解

    Boost是為C++語言標(biāo)準(zhǔn)庫提供擴展的一些C++程序庫的總稱。Boost庫是一個可移植、提供源代碼的C++庫,作為標(biāo)準(zhǔn)庫的后備,是C++標(biāo)準(zhǔn)化進程的開發(fā)引擎之一,是為C++語言標(biāo)準(zhǔn)庫提供擴展的一些C++程序庫的總稱
    2022-11-11
  • C++?STL中五個常用算法使用教程及實例講解

    C++?STL中五個常用算法使用教程及實例講解

    本文主要介紹了C++?STL算法中常見的五個算法的使用教程并附上了案例詳解,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-11-11
  • C語言malloc與calloc區(qū)別詳解

    C語言malloc與calloc區(qū)別詳解

    本文主要介紹了C語言malloc與calloc區(qū)別詳解,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-01-01
  • 利用Matlab繪制有趣圖像的示例代碼

    利用Matlab繪制有趣圖像的示例代碼

    這篇文章主要為大家總結(jié)了一些利用Matlab繪制的有趣好看的圖像的示例代碼。文中的示例代碼簡潔易懂,感興趣的小伙伴可以動手試一試
    2022-03-03

最新評論