文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

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

2024-04-02 19:55

关注

利用数组来创建一个三子棋小游戏的步骤如下:

1、建立一个可以容纳九个元素的3*3棋盘。并初始化,使所有位置都为三。
2、打印棋盘,使其尽可能美观。
3、玩家通过输入坐标(row,col)来落子。
4、判断输赢(是否有三个棋子相连)。
5、电脑随机落子(利用时间戳,实现真随机)。
6、判断输赢。

实现代码如下:


#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]){
 while (1){
  printf("请落子(row col)\n");
  int row = 0;
  int col = 0;
  scanf("%d %d", &row  &col);//录入玩家落子信息
  if (row >= MAX_ROW || row < 0 || col < 0 || col >= MAX_COL){
   printf("落子错误,请重新落子:\n");
   continue;
  }//判断玩家落子的合法性。
  else if (chessBoard[row][col] != ' '){
   printf("您输入的位置已经有棋子,请重新输入:\n");
   continue;
  }//判断该位置是否已有棋子。
  else{
   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] = '0';
  break;
 }
}
//判断棋盘是否已满,如果满输出0,没满输出1.
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 1;
   }
  }
 }
 return 0;
}
//判断谁获胜,可以约定如果返回‘x'玩家获胜
//如果返回‘0'电脑获胜
//返回‘ '则表示还未结束
//返回 's'表示和棋
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 's';
 }//判断是否和棋
 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 = '0'){
  printf("蠢,你输了!\n");
 }
 else{
  printf("和棋!\n");
 }
 return 0;
}

实现结果如下图:

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

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     801人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     348人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     311人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     432人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     220人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯