C语言三子棋解析

本文涉及的产品
云解析 DNS,旗舰版 1个月
全局流量管理 GTM,标准版 1个月
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
简介: C语言三子棋解析

开始菜单

void menu()//打印菜单
{
  printf("******************\n");
  printf("******1.play******\n");
  printf("******0.exit******\n");
  printf("******************\n");
}

打印棋盘

//存放下棋数据
char board[ROW][COL] = { 0 };
//初始化棋盘为全空格
InitBoard(board, ROW, COL);
//初始化棋盘为空格
void InitBoard(char board[ROW][COL], int row, int col)
{
  int i = 0;
  for (i = 0; i < row; i++)
  {
    int j = 0;
    for (j = 0; j < col; j++)
    {
      board[i][j] = ' ';
    }
  }
}
//打印棋盘
void DisplayBoard(char board[ROW][COL], int row, int col)//打印棋盘
{
  //打印数据
  int i = 0;
  for (i = 0; i < row; i++)
  {
    int j = 0;
    for (j = 0; j < col; j++)
    {
      printf(" %c ",board[i][j]);//别忘记board[i][j]
      if (j < col - 1)
      {
        printf("|");
      }
    }
    printf("\n");
    //打印分割行
    if (i < row-1)//记住   row-1
    {
      for (j = 0; j < col; j++)
      {
        printf("---");
        if (j < col - 1)
        {
          printf("|");
        }
      }
      printf("\n");
    }
  }
}

玩家下棋

//玩家下棋
void player_move(char board[ROW][COL], int row, int col)
{
  int x = 0;
  int y = 0;
  printf("玩家下棋\n");
  while (1)
  {
    printf("请输入坐标:");
    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] = '*';
        break;
      }
      else
      {
        printf("该坐标被占用,请重新输入\n");
      }
    }
    else
    {
      printf("非法坐标,请重新输入\n");
    }
  }

电脑下棋

void computer_move(char board[ROW][COL], int row, int col)
{
  int x = 0;
  int y = 0;
  printf("电脑下棋:>\n");
  while (1)
  {
    x = rand() % 3;//范围(a,b)用rand表示就是rand()%(b-a+1)
    y = rand() % 3;
    if (board[x][y] == ' ')//判断是否为空格,因为只有这一个条件,所以满足这个条件就可以下
    {
      board[x][y] = '#';
      break;
    }
  }
}

判断输赢

while (1)//玩家和电脑轮流下棋,直到一方胜利
  {   //玩家下棋
    player_move(board, ROW, COL);
    //打印棋盘
    DisplayBoard(board, ROW, COL);
    ret = is_win(board, ROW, COL);
    if (ret != 'C')
    {
      break;
    }
    //电脑下棋
    computer_move(board, ROW, COL);
    //打印棋盘
    DisplayBoard(board, ROW, COL);
    ret = is_win(board, ROW, COL);
    if (ret != 'C')
    {
      break;
    }
  }
  if (ret == '*')
  {
    printf("玩家获胜\n");
  }
  else if (ret == '#')
  {
    printf("电脑获胜\n");
  }
  else // (ret == 'Q')
  {
    printf("平局\n");
  }
  DisplayBoard(board, ROW, COL);
}
 //判断输赢
char is_win(char board[ROW][COL], int row, int col)
{
  //判断每一行是否都相等
  int i = 0;
  for (i = 0; i < col; i++)
  {
    if (board[i][0] == board[i][1] && board[i][1] == board[i][2] && board[i][1] != ' ')
    {
      return  board[i][1];
    }
  }
  //判断每一列是否都相等
  for (i = 0; i < col; i++)
  {
    if (board[0][i] == board[1][i] && board[1][i] == board[2][i] && board[1][i] != ' ')
    {
      return board[i][1];
    }
  }
  //判断对角线是否都相等
  if (board[0][0] == board[1][1] && board[1][1] == board[2][2] && board[1][1] != ' ')
  {
    return board[1][1];
  }
  if (board[0][2] == board[1][1] && board[1][1] == board[2][0] && board[1][1] != ' ')
  {
    return board[1][1];
  }
  //判断平局
  if (is_full(board, row, col) == 1)
  {
    return 'Q';
  }
  //继续
  return 'C';
}
目录
相关文章
|
5天前
|
存储 网络协议 编译器
【C语言】深入解析C语言结构体:定义、声明与高级应用实践
通过根据需求合理选择结构体定义和声明的放置位置,并灵活结合动态内存分配、内存优化和数据结构设计,可以显著提高代码的可维护性和运行效率。在实际开发中,建议遵循以下原则: - **模块化设计**:尽可能封装实现细节,减少模块间的耦合。 - **内存管理**:明确动态分配与释放的责任,防止资源泄漏。 - **优化顺序**:合理排列结构体成员以减少内存占用。
53 14
|
2月前
|
程序员 编译器 数据处理
【C语言】深度解析:动态内存管理的机制与实践
【C语言】深度解析:动态内存管理的机制与实践
|
2月前
|
Serverless 编译器 C语言
【C语言】指针篇- 深度解析Sizeof和Strlen:热门面试题探究(5/5)
【C语言】指针篇- 深度解析Sizeof和Strlen:热门面试题探究(5/5)
|
4月前
|
程序员 C语言
位操作在C语言中的解析与应用
位操作在C语言中的解析与应用
95 0
|
6月前
|
C语言
【海贼王编程冒险 - C语言海上篇】C语言如何实现简单的三子棋游戏?
【海贼王编程冒险 - C语言海上篇】C语言如何实现简单的三子棋游戏?
30 1
|
5月前
|
存储 C语言
C语言中static关键字的作用与用法解析
C语言中static关键字的作用与用法解析
|
6月前
|
C语言
C语言实现猜数字游戏:代码详解与函数解析
C语言实现猜数字游戏:代码详解与函数解析
266 0
|
6月前
|
自然语言处理 C语言 C++
程序与技术分享:C++写一个简单的解析器(分析C语言)
程序与技术分享:C++写一个简单的解析器(分析C语言)
|
6月前
|
存储 C语言
三子棋(C语言版)
三子棋(C语言版)
|
6月前
|
程序员 C语言 索引
【️C语言-游戏设置】---三子棋(N满)
【️C语言-游戏设置】---三子棋(N满)

推荐镜像

更多