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

C語言實現(xiàn)三子棋的示例代碼

 更新時間:2023年01月09日 16:02:43   作者:王十四兄  
所謂三子棋,就是三行三列的棋盤,玩家可以和電腦下棋,率先連成三個的獲勝。這篇文章主要為大家詳細介紹了如何通過C語言實現(xiàn)三子棋小游戲,感興趣的小伙伴可以嘗試一下

一、問題描述

用 c 語言實現(xiàn)三子棋。

二、基本流程

在寫三子棋的代碼之前,我們來看看實現(xiàn)這個游戲的邏輯:

1.菜單界面選擇開始或者退出游戲。

2.創(chuàng)建棋盤并初始化。

3.打印棋盤。

4.玩家落子(玩家輸入行列坐標的方式來落子),'x’表示玩家落子。

5.判定勝負關系(輸,贏,和棋),'q’表示和棋。

6.電腦落子(隨機位置落子) ,'o’表示電腦落子。

7.判定勝負關系。

8.回到 步驟 2 繼續(xù)執(zhí)行。

三、步驟

1. 菜單界面

1.開始游戲 0.退出游戲

int menu(){
printf("**************************\n");
printf("********1.開始游戲*********\n");
printf("********0.退出游戲*********\n");
printf("**************************\n");
int choice = 0;
printf("請輸入你的選擇:");
scanf("%d", &choice);
return choice;
}

2. 創(chuàng)建棋盤

棋盤:使用 3 行 3 列的二維數(shù)組來表示,元素類型是 char。

使用宏定義的原因:

1.推高代碼可讀性,后續(xù)代碼中遇到方便理解含義。

2.提高擴展性,如果將來要修改棋盤尺寸,代碼修改會很方便。

#define MAX_ROW 3
#define MAX_COL 3
char chessBoard[MAX_ROW][max_col] = { 0 };

3. 棋盤初始化

’ '表示棋盤上的空白區(qū)域

void init(char chessBoard[MAX_ROW][max_col]){
   for (int row = 0; row < MAX_ROW; row++){
     for (int col = 0; col < MAX_COL; col++){
       chessBoard[row][col] = ' ';
     }
   }
}

4.打印棋盤

(1)簡陋棋盤:

void print_chessBoard(char chessBoard[MAX_ROW][MAX_COL]){
   for (int row = 0; row <MAX_ROW; row++){
      for (int col = 0; col < MAX_COL; col++){
        printf("%c",chessBoard[row][col]) ;
      }
      printf("\n");
   }
}

結果:

注意:

這里不是棋盤沒打印出來,而是我們使用’ '表示空白區(qū)域,所以我們看到的棋盤是一片黑色。

這樣看的不是很清楚,所以我們選用更加美觀的方法打印。

(2)自己打印棋盤:

void print_chessBoard(char chessBoard[MAX_ROW][MAX_COL]){
    printf("+---+---+---+\n");
    for (int row = 0; row <MAX_ROW; row++) {
        printf("| %c | %c | %c |\n", chessBoard[row][0],
            chessBoard[row][1], chessBoard[row][2]);
        printf("+---+---+---+\n");
    }
}

結果:

5.玩家落子

玩家輸入行列坐標表示落子,使用’x’表示玩家落子。

注意:

1. 玩家落子需要在棋盤范圍內(nèi)。

2. 玩家要在棋盤上空的地方落子。

3. 如果輸入的坐標不滿足要重新輸入。

void playerMove(char chessBoard[MAX_ROW][MAX_COL]){
   while (1){
   int row = 0;
   int col = 0;
   printf("請輸入坐標(row col):");
   scanf("%d %d", &row, &col);
   if (row < 0 || row >= MAX_ROW || col < 0 || col >= MAX_COL){
    printf("您的坐標不在合法范圍內(nèi) [0, 2],請重新輸入:\n");
    continue;
   }
   if (chessBoard[row][col] != ' '){
    printf("您的坐標位置已經(jīng)有子了!\n");
    continue;
   }
   chessBoard[row][col] = 'x';
   break;
   }
}

6.電腦落子

電腦隨機產(chǎn)生行列坐標,'o’表示電腦落子。

注意:

1. 要在主函數(shù)中使用 srand((unsigned int)time(0))將時間作為隨機數(shù)種子,確保得到的行列坐標是真隨機。

2. 要在棋盤上空的地方下棋。

void computerMove(char chessBoard[MAX_ROW][MAX_COL]){
   while (1){
   int row = rand() % MAX_ROW;
   int col = rand() % MAX_COL;
   if (chessBoard[row][col] != ' ') {
    continue;
   }
   chessBoard[row][col] = 'o';
   break;
   }
}

7.判斷勝負

此處約定返回結果的含義:

(1)‘x’ 表示玩家獲勝

(2)‘o’ 表示電腦獲勝

(3)’ ’ 表示勝負未分

(4) ‘q’ 表示和棋

1) 判定是否和棋

(1)調(diào)用 isFull 函數(shù)。

(2)如果數(shù)組中有元素為’ ‘,那么沒滿,返回 0。如果全不為’ ',滿了,返回 1。

(3)如果棋盤滿了未分出勝負,和棋。

2) 判定電腦玩家勝利

(1)判定所有的行

(2)判定所有的列

(3)判定兩條對角線

int isFull(char chessBoard[MAX_ROW][MAX_COL]){
  for (int row = 0; row < MAX_ROW; row++){
    for (int col = 0; col < MAX_COL; col++){
      if (chessBoard[row][col] == ' '){
        return 0;
      }
    }
  }
  return 1;
}

char isWin(char chessBoard[MAX_ROW][MAX_COL]){
  for (int row = 0; row < MAX_ROW; row++) {
      if (chessBoard[row][0] != ' ' && chessBoard[row][0] == chessBoard[row][1] && chessBoard[row][0] == chessBoard[row][2]) {
        return chessBoard[row][0];
      }
  }
   for (int col = 0; col < MAX_COL; col++) {
    if (chessBoard[0][col] != ' ' && chessBoard[0][col] == chessBoard[1][col] && chessBoard[0][col] == chessBoard[2][col]) {
      return chessBoard[0][col];
    }
   }
   if (chessBoard[0][0] != ' ' && chessBoard[0][0] == chessBoard[1][1] && chessBoard[0][0] == chessBoard[2][2]) {
    return chessBoard[0][0];
   }
   if (chessBoard[2][0] != ' ' && chessBoard[2][0] == chessBoard[1][1] && chessBoard[2][0] == chessBoard[0][2]) {
    return chessBoard[2][0];
   }
   if (isFull(chessBoard)) {
    return 'q';
   }
   return ' ';
}

四、結果演示

1.玩家勝利

2.電腦勝利

3.和棋

五、代碼實現(xiàn)

#define _CRT_SECURE_NO_WARNINGS
#define MAX_ROW 3
#define MAX_COL 3
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
void init(char chessBoard[MAX_ROW][MAX_COL]){
  for (int row = 0; row < MAX_ROW; row++){
    for (int col = 0; col < MAX_COL; col++){
      chessBoard[row][col] = ' ';
    }
  }
}
void print_chessBoard(char chessBoard[MAX_ROW][MAX_COL]){
  printf("+---+---+---+\n");
  for (int row = 0; row <MAX_ROW; row++) {
    printf("| %c | %c | %c |\n", chessBoard[row][0],
      chessBoard[row][1], chessBoard[row][2]);
    printf("+---+---+---+\n");
  }
}
void playerMove(char chessBoard[MAX_ROW][MAX_COL]){
  while (1){
    int row = 0;
    int col = 0;
    printf("請輸入坐標(row col):");
    scanf("%d %d", &row, &col);
    if (row < 0 || row >= MAX_ROW || col < 0 || col >= MAX_COL){
      printf("您的坐標不在合法范圍內(nèi) [0, 2],請重新輸入:\n");
      continue;
    }
    if (chessBoard[row][col] != ' '){
      printf("您的坐標位置已經(jīng)有子了!\n");
      continue;
    }
    chessBoard[row][col] = 'x';
    break;
  }
}
void computerMove(char chessBoard[MAX_ROW][MAX_COL]){
  while (1){
    int row = rand() % MAX_ROW;
    int col = rand() % MAX_COL;
    if (chessBoard[row][col] != ' ') {
      continue;
    }
    chessBoard[row][col] = 'o';
    break;
  }
}
int isFull(char chessBoard[MAX_ROW][MAX_COL]){
  for (int row = 0; row < MAX_ROW; row++){
    for (int col = 0; col < MAX_COL; col++){
      if (chessBoard[row][col] == ' '){
        return 0;
      }

    }
  }
  return 1;
}
char isWin(char chessBoard[MAX_ROW][MAX_COL]){
  for (int row = 0; row < MAX_ROW; row++) {
    if (chessBoard[row][0] != ' '
      && chessBoard[row][0] == chessBoard[row][1]
      && chessBoard[row][0] == chessBoard[row][2]) {
      return chessBoard[row][0];
    }
  }
  for (int col = 0; col < MAX_COL; col++) {
    if (chessBoard[0][col] != ' '
      && chessBoard[0][col] == chessBoard[1][col]
      && chessBoard[0][col] == chessBoard[2][col]) {
      return chessBoard[0][col];
    }
  }
  if (chessBoard[0][0] != ' '
    && chessBoard[0][0] == chessBoard[1][1]
    && chessBoard[0][0] == chessBoard[2][2]) {
    return chessBoard[0][0];
  }
  if (chessBoard[2][0] != ' '
    && chessBoard[2][0] == chessBoard[1][1]
    && chessBoard[2][0] == chessBoard[0][2]) {
    return chessBoard[2][0];
  }
  if (isFull(chessBoard)) {
    return 'q';
  }
  return ' ';
}
void game(){
  char chessBoard[MAX_ROW][MAX_COL] = { 0 };
  init(chessBoard);
  char winner = ' ';
  while (1){
    system("cls");
    print_chessBoard(chessBoard);
    playerMove(chessBoard);
    winner = isWin(chessBoard);
    if (winner != ' ') {
      break;
    }
    computerMove(chessBoard);
    winner = isWin(chessBoard);
    if (winner != ' ') {
      break;
    }
  }
  print_chessBoard(chessBoard);
  if (winner == 'x') {
    printf("恭喜您, 您贏了!\n");
  }
  else if (winner == 'o') {
    printf("哈哈,您連人工智障都下不過!\n");
  }
  else {
    printf("您只能和人工智障打平手!!\n");
  }
}

int menu(){
   printf("**************************\n");
   printf("********1.開始游戲*********\n");
   printf("********0.退出游戲*********\n");
   printf("**************************\n");
  int choice = 0;
  printf("請輸入你的選擇:");
  scanf("%d", &choice);
  return choice;
}
int main()
{
  srand((unsigned int)time(0));
  while (1){
    int choice = menu();
    if (choice == 1){
      game();
    }
    else if (choice == 0){
      printf("退出游戲,GOODBYE!!!!!\n");
      break;
    }
    else{
      printf("輸入錯誤!請重新輸入!\n");
      continue;
    }
  }
  system("pause");
  return 0;
}

以上就是C語言實現(xiàn)三子棋的示例代碼的詳細內(nèi)容,更多關于C語言三子棋的資料請關注腳本之家其它相關文章!

相關文章

  • C語言基于循環(huán)鏈表解決約瑟夫環(huán)問題的方法示例

    C語言基于循環(huán)鏈表解決約瑟夫環(huán)問題的方法示例

    這篇文章主要介紹了C語言基于循環(huán)鏈表解決約瑟夫環(huán)問題的方法,簡單描述了約瑟夫環(huán)問題并結合實例形式分析了C語言使用循環(huán)鏈表解決約瑟夫環(huán)問題的具體操作技巧,需要的朋友可以參考下
    2018-01-01
  • C++實現(xiàn)一個簡單的線程池的示例代碼

    C++實現(xiàn)一個簡單的線程池的示例代碼

    本文主要介紹了C++實現(xiàn)一個簡單的線程池的示例代碼,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2022-05-05
  • C++移除序列中連續(xù)重復的特定值示例代碼

    C++移除序列中連續(xù)重復的特定值示例代碼

    這篇文章主要給大家介紹了關于在C++中如何移除序列中連續(xù)重復的特定值,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-01-01
  • C++零基礎精通數(shù)據(jù)結構之帶頭雙向循環(huán)鏈表

    C++零基礎精通數(shù)據(jù)結構之帶頭雙向循環(huán)鏈表

    帶頭雙向循環(huán)鏈表:結構最復雜,一般用在單獨存儲數(shù)據(jù)。實際中使用的鏈表數(shù)據(jù)結構,都是帶頭雙向循環(huán)鏈表。另外這個結構雖然結構復雜,但是使用代碼實現(xiàn)以后會發(fā)現(xiàn)結構會帶來很多優(yōu)勢,實現(xiàn)反而簡單
    2022-03-03
  • c++?error:crosses?initialization?of問題解決分析

    c++?error:crosses?initialization?of問題解決分析

    這篇文章主要介紹了c++?error:crosses?initialization?ofde?問題解決分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-08-08
  • C++?ncnn模型驗證精度實現(xiàn)代碼

    C++?ncnn模型驗證精度實現(xiàn)代碼

    這篇文章主要介紹了C++?ncnn模型驗證精度實現(xiàn)過程,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習吧
    2023-02-02
  • C++中不得不說的map容器

    C++中不得不說的map容器

    大家好,本篇文章主要講的是C++中不得不說的map容器,感興趣的同學趕快來看一看吧,對你有幫助的話記得收藏一下
    2022-02-02
  • 簡單了解C++語言中的二元運算符和賦值運算符

    簡單了解C++語言中的二元運算符和賦值運算符

    這篇文章主要介紹了C++語言中的二元運算符和賦值運算符,文中列出了可重載的運算符列表,需要的朋友可以參考下
    2016-01-01
  • 深入了解C++函數(shù)重載解析策略

    深入了解C++函數(shù)重載解析策略

    這篇文章主要為大家詳細介紹了C++中函數(shù)重載的解析策略,文中的示例代碼講解詳細,對我們學習C++有一定幫助,感興趣的小伙伴可以了解一下
    2022-10-10
  • C語言實現(xiàn)貪吃蛇游戲代碼

    C語言實現(xiàn)貪吃蛇游戲代碼

    大家好,本篇文章主要講的是C語言實現(xiàn)貪吃蛇游戲代碼,感興趣的同學趕快來看一看吧,對你有幫助的話記得收藏一下
    2022-02-02

最新評論