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

C語言實現(xiàn)三子棋程序

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

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

先直接上代碼:

#define _CRT_SECURE_NO_WARNINGS 1

#include<stdio.h>   //2.實現(xiàn)三子棋游戲。
#include<Windows.h>  //Sleep() RAND_MAX 的頭文件

void menu()      //打印菜單
{
 printf("****************************\n");
 printf("**** 歡迎來到三子棋游戲 ****\n");
 printf("**** 1、 進入游戲  ****\n");
 printf("**** 0、 退出游戲  ****\n");
 printf("****************************\n");
 printf("請輸入:->");
}

void print_chessboard(char coord[][3]) //打印棋盤函數(shù)
{  //多維數(shù)組在傳參時,接收數(shù)組的形參最多只能是第一個方括號里沒有數(shù)字(下標范圍)
   //否則就會出錯(因為此時編譯器不知道你要把傳過來的數(shù)組的元素劃分成幾行幾列,
   //但是當除第一個方括號的其他方括號都有值時,就可以經(jīng)過計算知道第一個方括號的值是多少
 int i = 0;
 int index_x = 0;
 int index_y = 0;
 for (i = 1; i <= 153; i++)
 {    
  char out_ch = ' ';
  if ((i % 51 == 20) || (i % 51 == 26) || (i % 51 == 32) )
  {
   out_ch = coord[index_x][index_y];
   index_x++;
   if (index_x < 3)
   {
    index_x = 0;
    index_y++;
   }
  }
  else if ((i % 17 == 6) || (i % 17 == 12))
  {
   out_ch = '|';
  }
  else if( (i >= 35 && i <= 51 && i != 40 && i != 46) || \
     (i >= 86 && i <= 102 && i != 91 && i != 97))
  {
   out_ch = '_';
  }
  putchar(out_ch);
  if (i % 17 == 0)     //每輸出 17 個字符換下一行輸出
  {
   printf("\n");
  }
 }
}

void winer(char coord[][3], int *flag);  //贏家判斷函數(shù)的聲明

int computer(char coord[][3])        //電腦下棋
{
 int flag = 0;
 int index_x2 = 0;
 int index_y2 = 0;
 srand((unsigned)time(NULL));
 while (1)
 {
  index_x2 = 2 * rand() / RAND_MAX;     //產(chǎn)生 0--2 的隨機數(shù)
  index_y2 = 2 * rand() / RAND_MAX;
  if ((coord[index_x2][index_y2] != '*') && (coord[index_x2][index_y2] != 'o'))
  {             //判斷該位置是否已有落子
   coord[index_x2][index_y2] = 'o';
   winer(coord, &flag);
   if (flag == 1)
   {
    return 1;
   }
   return 0;
  }
 }
}

int player(char coord[][3], int index_x1, int index_y1) //玩家下棋
{
 int flag = 0;
 int ret = 0;
 if ((coord[index_x1][index_y1] == '*') || (coord[index_x1][index_y1] == 'o'))
 {              //判斷該位置是否已有落子
  printf("此位置已有棋子,請重下!\n");
  return 0;
 }
 else
 {
  coord[index_x1][index_y1] = '*';
  winer(coord, &flag);
  if (flag == 1)
  {
   return 1;
  }
  ret = computer(coord);
  if (ret == 1)
  {
   return 1;
  }
  print_chessboard(coord);  //把打印棋盤放在是因為想在兩人都走完一次后再打印當前棋盤狀態(tài)
 }
 return 0;
}

void winer(char coord[][3],int *flag)   //判斷是否產(chǎn)生贏家,贏家是誰
{
 char line_ch[8][4] = { { coord[0][0], coord[1][1], coord[2][2] }, { coord[0][0], coord[0][1], coord[0][2] }, \
       { coord[0][0], coord[1][0], coord[2][0] }, { coord[0][1], coord[1][1], coord[2][1] }, \
       { coord[0][2], coord[1][2], coord[2][2] }, { coord[1][0], coord[1][1], coord[1][2] }, \
       { coord[2][0], coord[2][1], coord[2][2] }, { coord[0][2], coord[1][1], coord[2][0] } };
       //把所有能贏的情況定義成一個字符串數(shù)組
 int i = 0;
 for (i = 0; i < 8; i++)
 {
  if (strcmp(line_ch[i],"***") == 0) //判斷此時玩家已輸入的落子能不能組成一個使玩家能贏的字符串
  {
   print_chessboard(coord);   //先打印棋盤,再判斷誰勝誰負
   printf("\n恭喜您贏了!\n");
   *flag = 1;      //玩家贏,使最開始設(shè)置的贏的標志位為1,結(jié)束此次游戲
   return;
  }
  else if (strcmp(line_ch[i],"ooo") == 0)
  {
   print_chessboard(coord);
   printf("\n很遺憾,您輸了!\n");
   *flag = 1;
   return;
  }
  else
  {
   ;
  }
 }
}

int main()
{
 while (1)
 {
  int num = 0;   //決定開始或退出游戲
  int x = 0;
  int y = 0;
  int i = 4;    //一次游戲最多的內(nèi)層while循環(huán)可循環(huán)的次數(shù)
  int ret = 0;   //是否結(jié)束此次游戲的標志位
  int is_play = 0;  //是否再次玩游戲的標志位
  char coordinate[3][3] = { ' ', ' ', ' ', ' ', ' ', ' ', ' ', ' ', ' ' };
        //為了拓展游戲比較方便,可以把行和列定義成宏定義
  menu();     
  scanf("%d", &num);
  if (num == 0)
  {
   printf("5秒后退出程序!\n");
   Sleep(5000);
   exit(0);
  }
  computer(coordinate);  //因為設(shè)計電腦智商低,所以游戲開始前先讓電腦落一子
  print_chessboard(coordinate);
  while ((i))    //因為總共有九個位置可以落子,已用一個,還剩八個,每次循環(huán)不結(jié)束的話會用掉兩個
         //所以最多循環(huán)四次
  {
   printf("請輸入 X、Y 的坐標(0--2)來確定你下棋的位置:"); //也可以加一個判斷輸入是否合法
   scanf("%d %d", &x, &y);
   ret = player(coordinate, x, y);
   if (ret == 1)
   {
    break;
   }
   i--;
  } 
  printf("\n");
  printf("請選擇接下來的操作:\n");
  printf("1、 再玩一次游戲 0、退出游戲系統(tǒng)\n");
  scanf("%d", &is_play);
  if(is_play == 0)
  {
   printf("5秒后退出程序!\n");
   Sleep(5000);
   exit(0);
  }
  else
  {
   system("cls");
  }
 }
 system("pause");
 return 0;
}

程序一共設(shè)計了六個函數(shù),一個主函數(shù),五個自定義函數(shù)— 菜單打印函數(shù)、棋盤打印函數(shù)、電腦下棋函數(shù)、玩家下棋函數(shù)、贏家判斷函數(shù)。

其中最難設(shè)計的就是棋盤打印函數(shù)和贏家判斷函數(shù)。這兩個函數(shù)需要完成的任務(wù)多,計算量大,邏輯設(shè)計麻煩。

下面來分析一下幾個函數(shù)的設(shè)計思路:

1.菜單打印函數(shù)

這個函數(shù)很簡單,一看就能明白,這兒就不多說了。

2.棋盤打印函數(shù)

首先得構(gòu)思一下三子棋的棋盤應(yīng)該是什么樣

簡單點,上圖就可以作為三子棋棋盤(其實就是利用 putchar() 函數(shù)和 printf() 把顯示在屏幕上的字符一個個,一行行打印上去)。設(shè)計時可把其分成四部分來看,(1) 短豎杠 ; (2) 短橫杠 ; (3) 棋子(用一個二維字符數(shù)組來定義每一個棋子,用二維是因為方便輸入的 X 和 Y 值與數(shù)組下標對應(yīng)) ; (4) 空格(一開始打印的時候,因為還沒有落子,所以把棋子也設(shè)計成空格)。 先確定要輸入幾行幾列字符,以確定循環(huán)輸出的次數(shù),還有確定每個位置該輸出的字符,這樣就可以依靠循環(huán)和判斷打印出棋盤了。

3 . 贏家判斷函數(shù)

在每次落子后都要先進行一次判斷,看是否已經(jīng)產(chǎn)生贏家了。
因為會出現(xiàn)贏家的情況就八種———–

{ coord[0][0], coord[1][1], coord[2][2] }, { coord[0][0], coord[0][1], coord[0][2] },
{ coord[0][0], coord[1][0], coord[2][0] }, { coord[0][1], coord[1][1], coord[2][1] },
{ coord[2][0], coord[2][1], coord[2][2] }, { coord[1][0], coord[1][1], coord[1][2] },
{ coord[2][0], coord[2][1], coord[2][2] }, { coord[0][2], coord[1][1], coord[2][0] }

定義一個字符串數(shù)組,里面共有八個字符串,每一個字符串就是上面的一個花括弧里的內(nèi)容,當某個字符串的內(nèi)容與 * 或 ooo 相等,那么說明產(chǎn)生贏家了,否則不會產(chǎn)生贏家,那么就用一個循環(huán),遍歷字符串數(shù)組里的每一個字符串,判斷是否會產(chǎn)生贏家。

4. 玩家下棋函數(shù)

玩家通過輸入 x,y 坐標來確定落子的位置, x,y 對應(yīng)的就是 定義的棋子二維字符數(shù)組的下標,每次先判斷輸入的 x,y 值對應(yīng)數(shù)組下標的元素是否是 * 或 o ,是的話就說明此處已有落子,得重新輸入,不是的話就落下該棋子,接著判斷是否產(chǎn)生贏家,是的話就結(jié)束此次游戲,不是的話就判斷棋盤上是否還有空位置沒落子,有的話就輪到電腦繼續(xù)落子,沒有的話就結(jié)束此次游戲。

5. 電腦下棋函數(shù)

因為電腦是自動落子,所以得為電腦產(chǎn)生一個隨機的 棋子二維數(shù)組下標值,使電腦隨機落子,這個用srand((unsigned)time(NULL)); index_x2 = 2 * rand() / RAND_MAX; index_y2= 2 * rand() / RAND_MAX;來實現(xiàn)把它們放在一個while 死循環(huán)里,因為可能產(chǎn)生的兩個隨機下標那兒已經(jīng)有棋子了,需要重新產(chǎn)生一次隨機下標,當下標值與已落棋子不沖突時,就落下該棋子,接著判斷是否產(chǎn)生贏家,是的話,就結(jié)束此次游戲,不是的話就判斷棋盤上是否還有空位置沒落子,有的話就輪到玩家繼續(xù)落子,沒有的話就結(jié)束此次游戲。

6. 主函數(shù)

在主函數(shù)里適當調(diào)用以上定義的幾個函數(shù),實現(xiàn)正確的邏輯功能。

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

相關(guān)文章

  • C語言實現(xiàn)清空指定文件夾中所有文件的方法

    C語言實現(xiàn)清空指定文件夾中所有文件的方法

    這篇文章主要介紹了C語言實現(xiàn)清空指定文件夾中所有文件的方法,實例分析了C語言實現(xiàn)文件刪除的相關(guān)技巧,需要的朋友可以參考下
    2015-06-06
  • c++ 單線程實現(xiàn)同時監(jiān)聽多個端口

    c++ 單線程實現(xiàn)同時監(jiān)聽多個端口

    這篇文章主要介紹了c++ 單線程實現(xiàn)同時監(jiān)聽多個端口的方法,幫助大家更好的理解和學習使用c++,感興趣的朋友可以了解下
    2021-03-03
  • 深入講解Socket原理

    深入講解Socket原理

    這篇文章深入的講解Socket原理,并附帶實例代碼。小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2021-12-12
  • QString的常用方法(小結(jié))

    QString的常用方法(小結(jié))

    這篇文章主要介紹了QString的常用方法(小結(jié)),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-12-12
  • C語言中求字符串長度的函數(shù)的幾種實現(xiàn)方法

    C語言中求字符串長度的函數(shù)的幾種實現(xiàn)方法

    這篇文章主要介紹了C語言中求字符串長度的函數(shù)的幾種實現(xiàn)方法,需要的朋友可以參考下
    2018-08-08
  • C++雙向循環(huán)列表用法實例

    C++雙向循環(huán)列表用法實例

    這篇文章主要介紹了C++雙向循環(huán)列表,實例分析了C++雙向循環(huán)列表的創(chuàng)建、輸出、添加、刪除、移動的相關(guān)操作技巧,具有一定參考借鑒價值,需要的朋友可以參考下
    2015-07-07
  • C語言獲取數(shù)組長度的幾種方法

    C語言獲取數(shù)組長度的幾種方法

    這篇文章主要介紹了C語言獲取數(shù)組長度的幾種方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2021-01-01
  • 一篇文章帶你了解C++Primer學習日記--處理數(shù)據(jù)

    一篇文章帶你了解C++Primer學習日記--處理數(shù)據(jù)

    今天小編就為大家分享一篇關(guān)于C++對數(shù)器的使用講解,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2021-08-08
  • C語言判斷一個數(shù)是否為素數(shù)方法解析

    C語言判斷一個數(shù)是否為素數(shù)方法解析

    這篇文章主要介紹了C語言判斷一個數(shù)是否為素數(shù)方法,文中通過示例代碼介紹的非常詳細,對大家的學習具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-07-07
  • C++超詳細講解函數(shù)參數(shù)的默認值

    C++超詳細講解函數(shù)參數(shù)的默認值

    在C++中,定義函數(shù)時可以給形參指定一個默認的值,這樣調(diào)用函數(shù)時如果沒有給這個形參賦值(沒有對應(yīng)的實參),那么就使用這個默認的值。也就是說,調(diào)用函數(shù)時可以省略有默認值的參數(shù)
    2022-05-05

最新評論