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

C語言實現(xiàn)簡易版三子棋游戲

 更新時間:2020年07月17日 11:48:26   作者:浪漫不死  
這篇文章主要為大家詳細(xì)介紹了C語言實現(xiàn)簡易版三子棋游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下

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

什么是多文件?

多數(shù)大型的工程的頭文件和源文件非常多,我們也不可能把所有的代碼都寫在同一個文件里,這樣也不方便代碼的閱讀與維護(hù),通常都會根據(jù)不同的功能將代碼分別書寫到多個源文件與頭文件中。 

游戲介紹

三子棋是個簡單的雙人游戲,雙方在3X3的棋盤上輪流落子,當(dāng)一條直線上出現(xiàn)三顆連續(xù)且相同的棋子時即獲勝。此程序讓玩家先落子,電腦在棋盤上隨機(jī)落子。游戲結(jié)束時顯示勝負(fù),玩家可以選擇是否繼續(xù)玩游戲。

代碼實現(xiàn)

chess.h

通常我們會在頭文件中寫一些類型的定義、結(jié)構(gòu)體定義、宏定義、函數(shù)聲明、include包含等內(nèi)容。

#ifndef _CHESS_H_
#define _CHESS_H_
 
#include<stdio.h>
#include <stdlib.h>
#include <string.h>
#include <time.h>
#include<windows.h>
#pragma warning(disable:4996)
 
#define ROW 3
#define COL 3
 
#define BLACK_PIECE 'X'
#define WHITE_PIECE 'O'
 
void InitBoard(char board[ROW][COL], int row, int col);
void ShowBoard(char board[ROW][COL], int row, int col);
void PlayerMove(char board[ROW][COL], int row, int col);
int ComputerMove(char board[ROW][COL], int row, int col);
char CheckWin(char board[ROW][COL], int row, int col);
 
#endif

chess.c

源文件中包含了chess.h這個頭文件,于是在這個chess.c文件中就可以使用這些在頭文件中定義的內(nèi)容,可以使用自定義類型、自定義函數(shù)、標(biāo)準(zhǔn)輸入輸出函數(shù)等。

include的路徑問題,當(dāng)使用< >來指定包含的頭文件時,編譯器會從系統(tǒng)頭文件庫中進(jìn)行查找,而使用" "來包含的頭文件,編譯器將會從當(dāng)前程序目錄進(jìn)行查找。在include時被包含文件可以是絕對路徑,也可以是相對路徑,總之,只要頭文件的存放路徑與當(dāng)前源文件的關(guān)系正確即可。

#include "chess.h"
 
 
//打印棋盤
void InitBoard(char board[][COL], int row, int col)
{
 for (int i = 0; i < row; i++){
 for (int j = 0; j < col; j++){
  board[i][j] = ' ';
 }
 }
}
 
void ShowBoard(char board[][COL], int row, int col)
{
 printf("  | 1 | 2 | 3 |\n");
 int i = 0;
 for (; i < row; i++){
 printf("----------------\n");
 printf(" %d | %c | %c | %c |\n", i + 1, board[i][0], board[i][1], board[i][2]);
 }
 printf("----------------\n");
}
 
 
//玩家下棋
void PlayerMove(char board[][COL], int row, int col)
{
 int x = 0;
 int y = 0;
 printf("\n");
 printf("----------玩家走----------\n");
 printf("\n");
 while (1){
 printf("請輸入走的坐標(biāo)<x,y>:");
 scanf("%d%d", &x, &y);
 if (x >= 1 && x <= row && y >= 1 && y <= col){
  if (board[x - 1][y - 1] == ' '){
  board[x - 1][y - 1] = 'X';
  break;
  }
  else{
  printf("坐標(biāo)被占用,請重新輸入!\n");
  }
 }
 else{
  printf("坐標(biāo)有誤!\n");
 }
 }
}
 
 
//電腦下棋
int ComputerMove(char board[][COL], int row, int col)
{
 int x = 0;
 int y = 0;
 printf("\n");
 printf("----------電腦走----------\n");
 printf("\n");
 while (1){
 for (x = 0; x <= 2; x++){ //當(dāng)玩家有兩個子連成一條線時,堵!
  for (y = 0; y <= 2; y++){
  if (board[x][y] == ' '){
   board[x][y] = 'X';
   if (CheckWin(board, ROW, COL) == 'X'){
   board[x][y] = 'O'; //一旦落子,就直接跳出while循環(huán),后面都一樣
   Sleep(500);
   return 0;
   }
   else{
   board[x][y] = ' '; //還原
   }
  }
  }
 }
 if (board[1][1] == ' '){ //如果中間可以落子,在中間落子
  board[1][1] = 'O';
  Sleep(500);
  return 0;
 }
 else{ //如果四個角可以落子,在四個角上落子。
  for (x = 0; x <= 2; x += 2){
  for (y = 0; y <= 2; y += 2){
   if (board[x][y] == ' '){
   board[x][y] = 'O';
   Sleep(500);
   return 0;
   }
  }
  }
 }
 x = rand() % row; //四個邊的中間隨機(jī)落子,0—2
 y = rand() % col;
 if (board[x][y] == ' '){
  board[x][y] = 'O';
  Sleep(1000);
  break;
 }
 printf("\n");
 }
}
 
static int IsFull(char board[ROW][COL], int row, int col)
{
 int i = 0;
 int j = 0;
 for (i = 0; i < row; i++){
 for (j = 0; j < col; j++){
  if (board[i][j] == ' ')
  return 0;
 }
 }
 //已滿
 return 1;
}
 
//用戶贏了 BLACK_PIECE 'X'
//電腦贏了 WHITE_PIECE 'O'
//平局, 'Q'
//繼續(xù), 'C'
 
//結(jié)果判斷 玩家贏 or 電腦贏 or 平局
char CheckWin(char board[ROW][COL], int row, int col)
{
 int i = 0;
 for (; i < row; i++){
 //判斷一行是否相同
 if (board[i][0] != ' ' && board[i][0] == board[i][1] && board[i][1] == board[i][2]){
  return board[i][0];
 }
 }
 for (i = 0; i < col; i++){
 //判斷一列是否相同
 if (board[0][i] != ' ' && board[0][i] == board[1][i] && board[1][i] == board[2][i]){
  return board[0][i];
 }
 }
 if (board[0][0] != ' ' && board[0][0] == board[1][1] && board[1][1] == board[2][2]){
 return board[0][0];
 }
 if (board[0][2] != ' ' && board[0][2] == board[1][1] && board[1][1] == board[2][0]){
 return board[1][1];
 }
 //平局
 if (IsFull(board, row, col) == 1){
 return 'Q';
 }
 //繼續(xù)
 return 'C';
}

main.c

理清思路,搭建好運(yùn)行的框架。

1.游戲菜單,選擇玩/不玩
2.打印棋盤
3.玩家落子
4.打印棋盤
5.電腦落子
6.打印棋盤
7.…
8.顯示勝負(fù)
9.返回游戲菜單,選擇玩/不玩

#include "chess.h"
 
void Menu()
{
 printf("\n");
 printf("----------三子棋游戲----------\n");
 printf("\n");
 printf("******************************\n");
 printf("*      1.Play      *\n");
 printf("*      2.Exit      *\n");
 printf("******************************\n");
 printf("\n");
 printf("Please Enter Select:");
}
 
void Game()
{
 char board[ROW][COL] = { 0 };//記錄棋盤
 char ret = 0;
 InitBoard(board, ROW, COL);
 ShowBoard(board, ROW, COL);//打印棋盤
 
 while (1){
 PlayerMove(board, ROW, COL);//玩家走
 ShowBoard(board, ROW, COL);//打印棋盤
 //判斷輸贏
 ret = CheckWin(board, ROW, COL);
 if (ret != 'C'){
  break;
 }
 ComputerMove(board, ROW, COL);//電腦走
 ShowBoard(board, ROW, COL);//打印棋盤
 //判斷輸贏
 ret = CheckWin(board, ROW, COL);
 if (ret != 'C'){
  break;
 }
 }
 if (ret == 'X'){
 printf("----------玩家贏!----------\n");
 }
 else if (ret == 'O'){
 printf("----------電腦贏!----------\n");
 }
 else if (ret == 'Q'){
 printf("----------平局!----------\n");
 }
}
 
 
int main()
{
 int select = 0;
 int quit = 0;
 srand((unsigned int)time(NULL));
 
 while (!quit){
 Menu();
 scanf("%d", &select);
 
 switch (select){
 case 1:
  Game();
  while (!select);
  break;
 case 2:
  printf("Game Over!\n");
  break;
 default:
  printf("Enter Error!\n");
  break;
 }
 }
 system("pause");
 return 0;
}

測試結(jié)果

更多有趣的經(jīng)典小游戲?qū)崿F(xiàn)專題,分享給大家:

C++經(jīng)典小游戲匯總

python經(jīng)典小游戲匯總

python俄羅斯方塊游戲集合

JavaScript經(jīng)典游戲 玩不停

java經(jīng)典小游戲匯總

javascript經(jīng)典小游戲匯總

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

相關(guān)文章

  • C++ 自由存儲區(qū)是否等價于堆你知道嗎

    C++ 自由存儲區(qū)是否等價于堆你知道嗎

    自由存儲是C++中通過new與delete動態(tài)分配和釋放對象的抽象概念,而堆(heap)是C語言和操作系統(tǒng)的術(shù)語,是操作系統(tǒng)維護(hù)的一塊動態(tài)分配內(nèi)存
    2021-08-08
  • C語言實現(xiàn)餐飲管理與點(diǎn)餐系統(tǒng)

    C語言實現(xiàn)餐飲管理與點(diǎn)餐系統(tǒng)

    這篇文章主要為大家詳細(xì)介紹了C語言實現(xiàn)餐飲管理與點(diǎn)餐系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-01-01
  • C++算法與泛型算法(algorithm、numeric)

    C++算法與泛型算法(algorithm、numeric)

    這篇文章主要介紹了C++算法與泛型算法(algorithm、numeric),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-02-02
  • 帶你了解C++的數(shù)組與函數(shù)

    帶你了解C++的數(shù)組與函數(shù)

    這篇文章主要介紹了C++的數(shù)組與函數(shù),包括數(shù)組的初始化等基本知識,需要的朋友可以參考下,希望能給你帶來幫助
    2021-08-08
  • C語言遞歸實現(xiàn)字符串逆序的方式詳解

    C語言遞歸實現(xiàn)字符串逆序的方式詳解

    這篇文章主要介紹了C語言遞歸實現(xiàn)字符串逆序的方式詳解,本文通過實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-10-10
  • C語言使用函數(shù)實現(xiàn)字符串部分復(fù)制問題

    C語言使用函數(shù)實現(xiàn)字符串部分復(fù)制問題

    這篇文章主要介紹了C語言使用函數(shù)實現(xiàn)字符串部分復(fù)制問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-11-11
  • QT實戰(zhàn)之打開最近圖片功能的實現(xiàn)

    QT實戰(zhàn)之打開最近圖片功能的實現(xiàn)

    這篇文章主要為大家詳細(xì)介紹了如何利用Qt和QSettings實現(xiàn)打開最近圖片功能,文中的示例代碼講解詳細(xì),對我們學(xué)習(xí)QT有一定的幫助,感興趣的可以了解一下
    2022-06-06
  • C語言編程計算信噪比SNR理解學(xué)習(xí)

    C語言編程計算信噪比SNR理解學(xué)習(xí)

    這篇文章主要介紹了C語言編程信噪比SNR計算的理解學(xué)習(xí),信噪比,英文名稱叫做SNR或S/N(SIGNAL-NOISE RATIO)。是指一個電子設(shè)備或者電子系統(tǒng)中信號與噪聲的比例
    2021-10-10
  • Matlab繪制中國地圖超全教程詳解

    Matlab繪制中國地圖超全教程詳解

    這篇文章主要介紹了如何利用Matlab繪制中國地圖,文中的示例代碼講解詳細(xì),對我們學(xué)習(xí)Matlab有一定的幫助,感興趣的小伙伴可以學(xué)習(xí)一下
    2022-02-02
  • C++求所有頂點(diǎn)之間的最短路徑(用Floyd算法)

    C++求所有頂點(diǎn)之間的最短路徑(用Floyd算法)

    這篇文章主要為大家詳細(xì)介紹了C++求所有頂點(diǎn)之間的最短路徑,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-04-04

最新評論