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

適合初學(xué)者練習的C語言實現(xiàn)三子棋小游戲

 更新時間:2021年10月19日 14:32:47   作者:小明bite  
今天這篇文章主要介紹給大家分享一個適合初學(xué)者練習的利用C語言寫三子棋小游戲,用簡單的C語言來實現(xiàn)小時候玩的三子棋游戲,下面是人機對戰(zhàn),當然這個代碼的電腦對手是人工智障而不是人工智能 詳細內(nèi)容就請跟小編一起來閱讀下面文章內(nèi)容吧

用簡單的C語言來實現(xiàn)小時候玩的三子棋游戲,下面是人機對戰(zhàn),當然這個代碼的電腦對手是人工智障而不是人工智能

 一、寫代碼前明確下棋時的步驟與順序

  • 1.創(chuàng)建一個3*3的棋盤.
  • 2.將上面創(chuàng)建的棋盤中每個格初始化成' '狀態(tài).
  • 3.打印出初始化完成的棋盤
  • 4.玩家落子
  • 5.電腦落子
  • 6.判斷勝負

寫代碼之前梳理好大概的思路,先寫出初步的主函數(shù)

int main() {
 char winner = ' ';
 //1.創(chuàng)建一個棋盤,并初始化.
 char board[MAX_ROW][MAX_COL] = { 0 };
 //2.init函數(shù)將棋盤每個格子初始化成' '.
 init(board);
 while (1) {
  //3.打印棋盤
  printBoard(board);
  //4.玩家落子
  playerMove(board);
  //5.判斷勝負
  winner = checkWinner(board);
  if (winner != ' ') {
   //勝負已分
   break;
  }
  //6.電腦落子
  computerMove(board);
  //7.判斷勝負
  winner = checkWinner(board);
  if (winner != ' ') {
   //勝負已分
   break;
  }
 }


在創(chuàng)建棋盤是char board[][]的[]中不要寫3,寫3在后面看代碼時不能明確分清3代表什么

因此建議定義宏

#define MAX_ROW  3
#define MAX_COL  3


這樣可以清楚的看出[]中的內(nèi)容代表什么,提高可讀性.

 二 根據(jù)初步的主函數(shù)完成想要的代碼

1.寫一個函數(shù)來初始化棋盤

//將棋盤初始化成' '
void init(char board[MAX_ROW][MAX_COL]) {
 for (int row = 0; row < MAX_ROW; row++) {
  for(int col = 0; col < MAX_COL; col++) {
   board[row][col] = ' ';
  }
 }
 //設(shè)計隨機種子
 srand((unsigned int) time(0));
}
 

2.打印棋盤

void printBoard(char board[MAX_ROW][MAX_COL]) {
 system("cls");
 for (int row = 0; row < MAX_ROW; row++) {
  printf("+---+---+---+\n");
  for (int col = 0; col < MAX_COL; col++) {
   printf("| %c ", board[row][col]);
  }
  printf("|");
  printf("\n");
 }
 printf("+---+---+---+\n");
}


system("cls")是讓每次打印棋盤前清除之前的棋盤這樣能讓界面清晰一些

(使用的是簡單的C來完成程序所以打印的棋盤也比較簡陋)

3.玩家落子

void playerMove(char board[MAX_ROW][MAX_COL]) {
 printf("請玩家落子!");
 while (1) {
  printf("請輸入落子的位置(row col):");
  int row = 0;
  int col = 0;
  scanf("%d %d", &row, &col);
  //輸入后驗證輸入內(nèi)容是否合法.
  if (row < 0 || row >= MAX_ROW || col < 0 || col >= MAX_COL) {
   printf("輸入有誤.請重新輸入!\n");
   continue;
  }
  if (board[row][col] != ' ') {
   printf("當前位置已有棋子,請重新輸入!\n");
   continue;
  }
  board[row][col] = 'x';
  break;
 }
}


以輸入坐標的方式來實現(xiàn)落子,并且要檢測玩家落子是否合理,以免輸入無效的坐標.

4.電腦落子

void computerMove(char board[MAX_ROW][MAX_COL]) {
 printf("輪到電腦落子");
 while (1) {
  int row = rand() % MAX_ROW;
  int col = rand() % MAX_COL;
  if (board[row][col] != ' ') {
   continue;
  }
  board[row][col] = 'o';
  break;
 }
}


電腦落子采用隨機數(shù)的方式來進行落子,因此需要設(shè)置隨機種子,將它寫在初始化棋盤函數(shù)內(nèi),每次初始化一次進行一次隨機種子的設(shè)置

由于是隨機落子因此實現(xiàn)的不是人工智能而是人工智障.

5.判斷勝負

int checkWinner(char board[MAX_ROW][MAX_COL]) {
 //檢查所有行
 for (int row = 0; row < MAX_ROW; row++) {
  if (board[row][0] != ' ' && board[row][0] == board[row][1] && board[row][0] == board[row][2]) {
   return board[row][0];
  }
 }
 //檢查所有列
 for (int col = 0; col < MAX_COL; col++) {
  if (board[0][col] != ' ' && board[0][col] == board[1][col] && board[0][col] == board[2][col]) {
   return board[0][col];
  }
 }
 //檢查對角線
 if (board[0][0] == board[1][1] && board[0][0] == board[2][2] && board[0][0] != ' ') {
  return board[0][0];
 }
 if (board[0][2] == board[1][1] && board[0][2] == board[2][0] && board[0][2] != ' ') {
  return board[0][2];
 }
 if (isFull(board)) {
  return 'q';
 }
 return ' ';
}

檢查每行 每列  對角線是否有三個相同的棋子從而判斷勝負.

int isFull(char board[MAX_ROW][MAX_COL]) {
 for (int row = 0; row < MAX_ROW; row++) {
  for (int col = 0; col < MAX_COL; col++) {
   if (board[row][col] == ' ') {
    //棋盤沒滿
    return 0;
   }
  }
 }
 return 1;
}
 


檢查棋盤有沒有下滿(可能出現(xiàn)和棋)

 這就實現(xiàn)一個簡單的三子棋游戲

在主函數(shù)中玩家落子后應(yīng)也判斷一次勝負,以免出現(xiàn)玩家勝利電腦再落子的情況.

三、三子棋實現(xiàn)代碼

#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
#include<time.h>
 
#define MAX_ROW  3
#define MAX_COL  3
 
//將棋盤初始化成' '
void init(char board[MAX_ROW][MAX_COL]) {
 for (int row = 0; row < MAX_ROW; row++) {
  for(int col = 0; col < MAX_COL; col++) {
   board[row][col] = ' ';
  }
 }
 //設(shè)計隨機種子
 srand((unsigned int) time(0));
}
void printBoard(char board[MAX_ROW][MAX_COL]) {
 system("cls");
 for (int row = 0; row < MAX_ROW; row++) {
  printf("+---+---+---+\n");
  for (int col = 0; col < MAX_COL; col++) {
   printf("| %c ", board[row][col]);
  }
  printf("|");
  printf("\n");
 }
 printf("+---+---+---+\n");
}
void playerMove(char board[MAX_ROW][MAX_COL]) {
 printf("請玩家落子!");
 while (1) {
  printf("請輸入落子的位置(row col):");
  int row = 0;
  int col = 0;
  scanf("%d %d", &row, &col);
  //輸入后驗證輸入內(nèi)容是否合法.
  if (row < 0 || row >= MAX_ROW || col < 0 || col >= MAX_COL) {
   printf("輸入有誤.請重新輸入!\n");
   continue;
  }
  if (board[row][col] != ' ') {
   printf("當前位置已有棋子,請重新輸入!\n");
   continue;
  }
  board[row][col] = 'x';
  break;
 }
}
void computerMove(char board[MAX_ROW][MAX_COL]) {
 printf("輪到電腦落子");
 while (1) {
  int row = rand() % MAX_ROW;
  int col = rand() % MAX_COL;
  if (board[row][col] != ' ') {
   continue;
  }
  board[row][col] = 'o';
  break;
 }
}
int isFull(char board[MAX_ROW][MAX_COL]) {
 for (int row = 0; row < MAX_ROW; row++) {
  for (int col = 0; col < MAX_COL; col++) {
   if (board[row][col] == ' ') {
    //棋盤沒滿
    return 0;
   }
  }
 }
 return 1;
}
int checkWinner(char board[MAX_ROW][MAX_COL]) {
 //檢查所有行
 for (int row = 0; row < MAX_ROW; row++) {
  if (board[row][0] != ' ' && board[row][0] == board[row][1] && board[row][0] == board[row][2]) {
   return board[row][0];
  }
 }
 //檢查所有列
 for (int col = 0; col < MAX_COL; col++) {
  if (board[0][col] != ' ' && board[0][col] == board[1][col] && board[0][col] == board[2][col]) {
   return board[0][col];
  }
 }
 //檢查對角線
 if (board[0][0] == board[1][1] && board[0][0] == board[2][2] && board[0][0] != ' ') {
  return board[0][0];
 }
 if (board[0][2] == board[1][1] && board[0][2] == board[2][0] && board[0][2] != ' ') {
  return board[0][2];
 }
 if (isFull(board)) {
  return 'q';
 }
 return ' ';
}
int main() {
 char winner = ' ';
 //1.創(chuàng)建一個棋盤,并初始化.
 char board[MAX_ROW][MAX_COL] = { 0 };
 //2.init函數(shù)將棋盤每個格子初始化成' '.
 init(board);
 while (1) {
  //3.打印棋盤
  printBoard(board);
  //4.玩家落子
  playerMove(board);
  //5.判斷勝負
  winner = checkWinner(board);
  if (winner != ' ') {
   //勝負已分
   break;
  }
  //6.電腦落子
  computerMove(board);
  //7.判斷勝負
  winner = checkWinner(board);
  if (winner != ' ') {
   //勝負已分
   break;
  }
 }
 if (winner == 'x') {
  printf("恭喜你,你贏了!\n");
 }else if(winner=='o') {
  printf("你真菜連人工智障都玩不過\n");
 }else {
  printf("你和人工智障五五開\n");
 }
 return 0;
}

運行界面如下:

到此這篇關(guān)于初學(xué)者練習--C語言寫三子棋小游戲的文章就介紹到這了,更多相關(guān)C語言寫三子棋小游戲內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • C語言 操作符#與##使用方法詳解

    C語言 操作符#與##使用方法詳解

    在類函數(shù)宏中(帶參數(shù)的宏),#號作為一個預(yù)處理運算符,可以把記號轉(zhuǎn)換成字符串。##相當于連接符,它會將兩邊的內(nèi)容連接起來,形成新的標識符,下面請看詳細的教程
    2022-04-04
  • C++ Clock類模擬實現(xiàn)鬧鐘運行

    C++ Clock類模擬實現(xiàn)鬧鐘運行

    這篇文章主要為大家詳細介紹了C++ Clock類模擬實現(xiàn)鬧鐘運行,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • C++利用inotify+epoll實現(xiàn)異步文件監(jiān)控的方法

    C++利用inotify+epoll實現(xiàn)異步文件監(jiān)控的方法

    這篇文章講給大家詳細介紹一下C++利用inotify+epoll實現(xiàn)異步文件監(jiān)控的方法,inotify是一種異步文件監(jiān)控機制,文章通過代碼示例介紹的非常詳細,具有一定的參考價值,需要的朋友可以參考下
    2023-08-08
  • C語言利用數(shù)組和文件實現(xiàn)登錄注冊功能

    C語言利用數(shù)組和文件實現(xiàn)登錄注冊功能

    這篇文章主要為大家詳細介紹了C語言利用數(shù)組和文件實現(xiàn)登錄注冊功能,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-12-12
  • C++中new的用法及說明

    C++中new的用法及說明

    這篇文章主要介紹了C++中new的用法及說明,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-11-11
  • VS2019調(diào)試C語言程序(監(jiān)視操作)的詳細步驟

    VS2019調(diào)試C語言程序(監(jiān)視操作)的詳細步驟

    在很多時候我們在寫程序的過程中會發(fā)現(xiàn)一些非編程錯誤的問題,這樣的問題很難直接分辨出來,但是我們可以用調(diào)試了一步一步的模擬程序運行的過程,來找出程序的錯誤,下面這篇文章主要給大家介紹了關(guān)于VS2019調(diào)試C語言程序(監(jiān)視操作)的詳細步驟,需要的朋友可以參考下
    2022-11-11
  • c++使用Easyx圖形庫實現(xiàn)飛機大戰(zhàn)

    c++使用Easyx圖形庫實現(xiàn)飛機大戰(zhàn)

    本文詳細講解了c++使用Easyx圖形庫實現(xiàn)飛機大戰(zhàn),文中通過示例代碼介紹的非常詳細。對大家的學(xué)習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-12-12
  • Qt5.9實現(xiàn)簡單的多線程實例(類QThread)

    Qt5.9實現(xiàn)簡單的多線程實例(類QThread)

    Qt開啟多線程,主要用到類QThread。用一個類繼承QThread,然后重新改寫虛函數(shù)run()。具有一定的參考價值,感興趣的可以了解一下
    2021-09-09
  • C語言中的strlen()和sizeof()對比分析

    C語言中的strlen()和sizeof()對比分析

    這篇文章主要介紹了C語言中的strlen()和sizeof()區(qū)別對比,本文給大家介紹的非常詳細,對大家的學(xué)習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-03-03
  • C++ 實現(xiàn)球迷 今日頭條面試題

    C++ 實現(xiàn)球迷 今日頭條面試題

    這篇文章主要介紹了C++實現(xiàn)球迷今日頭條面試題功能,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下
    2018-08-08

最新評論