C语言代码实现简易三子棋游戏

 更新时间:2021年05月08日 08:45:20   作者:小甜包  
这篇文章主要为大家详细介绍了C语言代码实现简易三子棋游戏,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

本文实例为大家分享了C语言代码实现简易三子棋游戏的具体代码,供大家参考,具体内容如下

1. 三子棋游戏规则

是黑白棋的一种。三子棋是一种民间传统游戏,又叫九宫棋、圈圈叉叉、一条龙、井字棋等。将正方形对角线连起来,相对两边依次摆上三个双方棋子,只要将自己的三个棋子走成一条线,对方就算输了。但是,有很多时候会出现和棋的情况。

2.设计思路

游戏流程:

1.创建棋盘,并且初始化,将所有位置设置为空格。
2.打印棋盘
3.玩家通过输入坐标(row,col)进行落子
4.判定胜负
5.电脑随机落子
6.判断胜负

具体实现:

1.用一个3*3的二维数组来表示棋盘,数组的每个元素是char类型
2."x"表示玩家1,"o"表示玩家2,空格即为空白。
3.rand&srand控制电脑随机落子

3.代码详解

(1).3为魔幻数字,为了避免混乱则使用宏定义

#define MAX_ROW 3
#define MAX_COL  3
char chessBoard[3]3];
char chessBoard[MAX_ROW][MAX_COL];

不建议定义为全局变量

(2).初始化函数 将棋盘的每一个位置都初始化为空格

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

(3).打印棋盘

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

通过不断调整符号来确定棋盘

(4).玩家落子

要判断输入数值是否合法,不可以下标越界,如果不合法要重新输入。
以及输入位置是否有子,如果有子要提醒用户重新输入。

void playerMove(char chessBoard[MAX_ROW][MAX_COL]) 
{
 printf("玩家落子....\n");
 while (1) 
 {
  printf("请输入坐标(row col): ");
  int row = 0;
  int col = 0;
  scanf("%d %d", &row, &col);
  if (row < 0 || row >= MAX_ROW || col < 0 || col >= MAX_COL) 
  {
   printf("输入坐标非法! 请重新输入!\n");
   continue;
  }
  if (chessBoard[row][col] != ' ') 
  {
   printf("已经有子, 请重新输入!\n");
   continue;
  }
  chessBoard[row][col] = 'x';
  break;
 }
}

(5)判断胜负

如果返回 x, 表示 玩家获胜;返回 o, 表示 电脑获胜;返回 ' ', 表示胜负未分
;返回 q, 表示和棋。

char isGameOver(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[0][2] != ' '
  && chessBoard[0][2] == chessBoard[1][1]
  && chessBoard[0][2] == chessBoard[2][0])
 {
  return chessBoard[0][2];
 }
 // 判定是否和棋
 //棋盘是否满了
 if (isFull(chessBoard)) 
 {
  return 'q';
 }
 // 胜负未分
 return ' ';
}

(6)电脑落子

需要判断落子位置之前是否有子

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满 0不满

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;
}

4.完整代码

include <stdio.h>
#include <stdlib.h>
#define MAX_ROW 3
#define MAX_COL 3
void init(char chess[MAX_ROW][MAX_COL]) 
{
 for (int row = 0; row < MAX_ROW; row++)
 {
  for (int col = 0; col < MAX_COL; col++)
  {
   chess[row][col] = ' ';
  }
 }
}

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

void playerMove(char chessBoard[MAX_ROW][MAX_COL]) 
{
 printf("玩家落子....\n");
 while (1) 
 {
  printf("请输入坐标(row col): ");
  int row = 0;
  int col = 0;
  scanf("%d %d", &row, &col);
  if (row < 0 || row >= MAX_ROW || col < 0 || col >= MAX_COL) 
  {
   printf("您输入的坐标非法! 请重新输入!\n");
   continue;
  }
  if (chessBoard[row][col] != ' ') 
  {
   printf("您输入的位置已经有子了, 请重新输入!\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;
 }
}

// 返回 1 满, 0不满
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 isGameOver(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[0][2] != ' '
  && chessBoard[0][2] == chessBoard[1][1]
  && chessBoard[0][2] == chessBoard[2][0])
 {
  return chessBoard[0][2];
 }
 
 if (isFull(chessBoard)) 
 {
  return 'q';
 }
 return ' ';
}

int main()
{

 char chessBoard[MAX_ROW][MAX_COL];
 init(chessBoard);
 char winner = ' ';
 while (1) 
 {
  print(chessBoard);
  playerMove(chessBoard);
  winner = isGameOver(chessBoard);
  if (winner != ' ') 
  {
   break;
  }
  computerMove(chessBoard);
  winner = isGameOver(chessBoard);
  if (winner != ' ') 
  {
   break;
  }
 }
 if (winner == 'x') 
 {
  printf("赢!\n");
 }
 else if (winner == 'o') 
 {
  printf("蠢!\n");
 }
 else 
 {
  printf("五五开!\n");
 }


 system("pause");
 return 0;
 }

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • c++隐式类型转换存在的问题解析

    c++隐式类型转换存在的问题解析

    隐式转换,是指不需要用户干预,编译器私下进行的类型转换行为,很多时候用户都不知道具体进行了哪些转换,这篇文章主要介绍了c++隐式类型转换存在的陷阱,需要的朋友可以参考下
    2022-03-03
  • C语言递归系列的深入总结

    C语言递归系列的深入总结

    这篇文章主要给大家总结介绍了关于C语言递归系列的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-02-02
  • C语言按关键字搜索文件夹中文件的方法

    C语言按关键字搜索文件夹中文件的方法

    这篇文章主要介绍了C语言按关键字搜索文件夹中文件的方法,涉及C语言文件操作及字符串查找的相关技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-07-07
  • C语言 从根本上理解指针

    C语言 从根本上理解指针

    C语言这门课程在计算机的基础教学中一直占有比较重要的地位,然而要想突破C语言的学习,对指针的掌握是非常重要的,本文将具体针对指针的基础做详尽的介绍
    2022-04-04
  • 详解C语言未初始化的局部变量是多少

    详解C语言未初始化的局部变量是多少

    这篇文章主要给大家介绍了关于C语言未初始化的局部变量是多少,文中通过示例代码以及图文介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2020-07-07
  • C++使用OpenCV进行物体识别与检测的三种方法

    C++使用OpenCV进行物体识别与检测的三种方法

    物体识别与检测是计算机视觉中的核心任务之一,它被广泛应用于自动驾驶、安防监控、图像分析等领域,通过物体检测技术,计算机能够从图像中识别出特定的物体或目标,本文将介绍如何使用 C++ 和 OpenCV 库进行物体识别与检测,需要的朋友可以参考下
    2025-04-04
  • C++中关于std::queue 中遇到释放内存错误的问题

    C++中关于std::queue 中遇到释放内存错误的问题

    这篇文章主要介绍了std::queue中遇到释放内存错误的问题,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-07-07
  • C语言数据结构系列队列篇

    C语言数据结构系列队列篇

    本章我们将学习 "队列" ,首先介绍队列的概念和结构,然后我们将着重讲解栈的实现。我们从零开始写队列的接口,并从零开始步步解读。本章将继续巩固画思路草图的能力,只要思路草图画好了,就可以很轻松地将其转换成代码
    2022-02-02
  • C语言循环控制入门介绍

    C语言循环控制入门介绍

    大家好,本篇文章主要讲的是C语言循环控制入门介绍,感兴趣的同学赶快来看一看吧,对你有帮助的话记得收藏一下,方便下次浏览
    2022-01-01
  • 关于C语言qsort函数详解

    关于C语言qsort函数详解

    这篇文章主要介绍了关于C语言qsort函数详解的相关资料,需要的朋友可以参考下面文章内容
    2021-09-09

最新评论