设为首页收藏本站
网站公告 | 这是第一条公告
     

 找回密码
 立即注册
缓存时间20 现在时间20 缓存数据 和聪明人交流,和靠谱的人恋爱,和进取的人共事,和幽默的人随行。晚安!

和聪明人交流,和靠谱的人恋爱,和进取的人共事,和幽默的人随行。晚安!

查看: 1666|回复: 3

基于C语言实现井字棋游戏

[复制链接]

  离线 

TA的专栏

  • 打卡等级:热心大叔
  • 打卡总天数:240
  • 打卡月天数:1
  • 打卡总奖励:3573
  • 最近打卡:2025-12-14 07:36:21
等级头衔

等級:晓枫资讯-上等兵

在线时间
0 小时

积分成就
威望
0
贡献
422
主题
385
精华
0
金钱
4835
积分
890
注册时间
2023-1-3
最后登录
2025-12-14

发表于 2023-2-13 15:40:14 | 显示全部楼层 |阅读模式
井字棋游戏要求在3乘3棋盘上,每行都相同或者每列都相同再或者对角线相同,则胜出.因此我们可以使用一个二维数组来表示棋盘,判断胜负只需要判断数组元素是否相同即可.具体我们可以分为以下几步来做:
1.创建维数组并进行初始化,如果仅仅是一个二维数组来表示棋盘,看起来不是很清楚,因此我们可以对棋盘边框用符号打印出来进行优化一下:
  1. //初始化棋盘
  2. void init(char board[max_row][max_col]) {
  3. for (int row = 0; row < max_row; row++) {
  4.   for (int col = 0; col < max_col; col++) {
  5.    board[row][col] =' ';
  6.   }
  7. }
  8. srand((unsigned int)time(0));
  9. }
  10. //打印棋盘
  11. void print(char board[max_row][max_col]) {
  12. system("cls");//每次打印之前清除掉上一次的结果.
  13. for (int a = 0; a < max_col; a++) {
  14.   printf("+---+---+---+\n");
  15.   for (int b = 0; b < max_row; b++) {
  16.    printf("| %c ", board[a][b]);
  17.   }
  18.   printf("| \n");
  19. }
  20. printf("+---+---+---+\n");
  21. }
复制代码
2.进行玩家落子,同样是使用数组操作,让玩家输入相对应的坐标,在二维数组的该位置打印'x'来表示玩家下的棋子
  1. void play(char board[max_row][max_col]) {
  2. printf("玩家落子阶段!\n");
  3. int a;
  4. int b;
  5. while (1) {
  6.   printf("请输入想要落子的坐标: ");
  7.   scanf("%d %d", &a, &b);
  8.   //判定玩家落子坐标是否在有效范围内
  9.   if (a < 0 || b < 0 || a >= max_row || b >= max_col) {   
  10.    printf("输入坐标有误请重新输入!\n");                 
  11.    continue;
  12.   }
  13.   //判定落子处是否已经存在了棋子
  14.   if (board[b][a] != ' ') {                                
  15.    printf("此处已被落子无法再落子,请重新输入!\n");
  16.    continue;
  17.   }
  18.   board[b][a] = 'x';       //用'x'表示玩家落子
  19.   break;
  20. }
  21. }
复制代码
3.玩家落子结束后让电脑在二维数组中随机落子,使用rand函数产生0到2的随机数进行赋值操作,进而实现电脑随机落子
  1. void computer(char board[max_row][max_col]) {
  2. printf("电脑落子阶段!\n");
  3. while (1) {
  4.   int a = rand() % max_row; //产生0到2的随机数
  5.   int b = rand() % max_col;
  6.   if (board[a][b] != ' ') { //判断所下位置是否已经有子
  7.    continue;
  8.   }
  9.   board[a][b] = 'o';
  10.   break;
  11. }
复制代码
4.判断胜负,当玩家落子结束,或者电脑落子结束后,判断是否存在某行或某列或者对角线有相同的元素,如果有则直接判定结果,如果没有则轮到下家落子
  1. char check(char board[max_row][max_col]) {
  2. //检测所有行是否相等
  3. for (int cow = 0; cow < max_row; cow++) {
  4.   if (board[cow][0] != ' ' && board[cow][0] == board[cow][1] && board[cow][0]==board[cow][2] ) {
  5.    return board[cow][0];
  6.   }
  7. }
  8. //检测所有列是否相等
  9. for (int col = 0; col < max_col; col++) {
  10.   if (board[0][col] != ' ' && board[0][col] == board[1][col] && board[0][col]==board[2][col] ) {
  11.    return board[0][col];
  12.   }
  13. }
  14. //检测对角线是否相等
  15. if (board[0][0] != ' ' && board[0][0] == board[1][1] && board[0][0] == board[2][2]) {
  16.   return board[0][0];
  17. }
  18. if (board[0][2] != ' ' && board[0][2] == board[1][1] && board[0][2] == board[2][0]) {
  19.   return board[0][2];
  20. }
  21. if (pingju(board)) {
  22.   return 'q';   //棋子已满和棋
  23. }
  24. return 'a';       //棋盘未满
  25. }
  26. //判断棋盘是否棋子已满,如果满了返回1,未满返回0.
  27. int pingju(char board[max_row][max_col]) {
  28. for (int row = 0; row < max_row; row++) {
  29.   for (int col = 0; col < max_col; col++) {
  30.    if (board[row][col] == ' ') {
  31.     return 0;
  32.    }
  33.   }
  34. }
  35. return 1;
  36. }
复制代码
5.在主函数中调用以上函数,进行操作:
  1. int main() {
  2. char board[max_row][max_col] = {0};//数组初始化为0
  3. char winner = 'n';
  4. init(board); //将棋盘中元素初始化为空格
  5. while (1) {
  6.   print(board);  //打印棋盘
  7.   play(board);   //玩家落子
  8.   winner = check(board);  //判断胜负
  9.   if (winner != 'a') {   
  10.    break;
  11.   }
  12.   computer(board);      //电脑落子
  13.   winner = check(board);  //判断胜负
  14.   if (winner != 'a') {
  15.    break;
  16.   }
  17. }

  18.   if (winner == 'x') {
  19.    print(board);
  20.    printf("你赢了!");
  21.   }
  22.   else if (winner == 'o') {
  23.    print(board);
  24.    printf("你输了!");
  25.   }
  26.   else if (winner == 'q') {
  27.    print(board);
  28.    printf("和棋!");
  29.   }
  30. return 0;
复制代码
在主函数中利用while循环来实现玩家与电脑的轮流落子,如果当一方落子之后胜负已出,则跳出循环直接打印最终结果.
完整代码如下:
  1. #include <stdio.h>#include <stdlib.h>#include <time.h>#include <windows.h>#define max_row 3#define max_col 3//初始化棋盘
  2. void init(char board[max_row][max_col]) {
  3. for (int row = 0; row < max_row; row++) {
  4.   for (int col = 0; col < max_col; col++) {
  5.    board[row][col] =' ';
  6.   }
  7. }
  8. srand((unsigned int)time(0));
  9. }
  10. //打印棋盘
  11. void print(char board[max_row][max_col]) {
  12. system("cls");//每次打印之前清除掉上一次的结果.
  13. for (int a = 0; a < max_col; a++) {
  14.   printf("+---+---+---+\n");
  15.   for (int b = 0; b < max_row; b++) {
  16.    printf("| %c ", board[a][b]);
  17.   }
  18.   printf("| \n");
  19. }
  20. printf("+---+---+---+\n");
  21. } //玩家落子void play(char board[max_row][max_col]) { printf("玩家落子阶段!\n"); int a; int b; while (1) {  printf("请输入想要落子的坐标: ");  scanf("%d %d", &a, &b);  //判定玩家落子坐标是否在有效范围内  if (a < 0 || b < 0 || a >= max_row || b >= max_col) {      printf("输入坐标有误请重新输入!\n");                    continue;  }  //判定落子处是否已经存在了棋子  if (board[a][b] != ' ') {                                   printf("此处已被落子无法再落子,请重新输入!\n");   continue;  }  board[a][b] = 'x';       //用'x'表示玩家落子  break; }}//void computer(char board[max_row][max_col]) {
  22. printf("电脑落子阶段!\n");
  23. while (1) {
  24.   int a = rand() % max_row; //产生0到2的随机数
  25.   int b = rand() % max_col;
  26.   if (board[a][b] != ' ') { //判断所下位置是否已经有子
  27.    continue;
  28.   }
  29.   board[a][b] = 'o';
  30.   break;
  31. }// }//char check(char board[max_row][max_col]) { //检测所有行是否相等 for (int cow = 0; cow < max_row; cow++) {  if (board[cow][0] != ' ' && board[cow][0] == board[cow][1] && board[cow][0]==board[cow][2] ) {   return board[cow][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[0][0] == board[1][1] && board[0][0] == board[2][2]) {  return board[0][0]; } if (board[0][2] != ' ' && board[0][2] == board[1][1] && board[0][2] == board[2][0]) {  return board[0][2]; } if (pingju(board)) {  return 'q'; } return 'a';}//判断棋盘是否棋子已满,如果满了返回1,未满返回0.int pingju(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 main() {
  32. char board[max_row][max_col] = {0};//数组初始化为0
  33. char winner = 'n';
  34. init(board); //将棋盘中元素初始化为空格
  35. while (1) {
  36.   print(board);  //打印棋盘
  37.   play(board);   //玩家落子
  38.   winner = check(board);  //判断胜负
  39.   if (winner != 'a') {   
  40.    break;
  41.   }
  42.   computer(board);      //电脑落子
  43.   winner = check(board);  //判断胜负
  44.   if (winner != 'a') {
  45.    break;
  46.   }
  47. }

  48.   if (winner == 'x') {
  49.    print(board);
  50.    printf("你赢了!");
  51.   }
  52.   else if (winner == 'o') {
  53.    print(board);
  54.    printf("你输了!");
  55.   }
  56.   else if (winner == 'q') {
  57.    print(board);
  58.    printf("和棋!");
  59.   }
  60. return 0;}
复制代码
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持晓枫资讯。

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!
晓枫资讯-科技资讯社区-免责声明
免责声明:以上内容为本网站转自其它媒体,相关信息仅为传递更多信息之目的,不代表本网观点,亦不代表本网站赞同其观点或证实其内容的真实性。
      1、注册用户在本社区发表、转载的任何作品仅代表其个人观点,不代表本社区认同其观点。
      2、管理员及版主有权在不事先通知或不经作者准许的情况下删除其在本社区所发表的文章。
      3、本社区的文章部分内容可能来源于网络,仅供大家学习与参考,如有侵权,举报反馈:点击这里给我发消息进行删除处理。
      4、本社区一切资源不代表本站立场,并不代表本站赞同其观点和对其真实性负责。
      5、以上声明内容的最终解释权归《晓枫资讯-科技资讯社区》所有。
http://bbs.yzwlo.com 晓枫资讯--游戏IT新闻资讯~~~

  离线 

TA的专栏

等级头衔

等級:晓枫资讯-列兵

在线时间
0 小时

积分成就
威望
0
贡献
0
主题
0
精华
0
金钱
14
积分
8
注册时间
2022-12-27
最后登录
2022-12-27

发表于 2025-7-18 14:33:20 | 显示全部楼层
感谢楼主,顶。
http://bbs.yzwlo.com 晓枫资讯--游戏IT新闻资讯~~~

  离线 

TA的专栏

等级头衔

等級:晓枫资讯-列兵

在线时间
0 小时

积分成就
威望
0
贡献
0
主题
0
精华
0
金钱
19
积分
18
注册时间
2022-12-25
最后登录
2022-12-25

发表于 2025-9-12 03:22:35 | 显示全部楼层
感谢楼主分享。
http://bbs.yzwlo.com 晓枫资讯--游戏IT新闻资讯~~~

  离线 

TA的专栏

等级头衔

等級:晓枫资讯-列兵

在线时间
0 小时

积分成就
威望
0
贡献
0
主题
0
精华
0
金钱
11
积分
2
注册时间
2023-10-30
最后登录
2023-10-30

发表于 2025-9-30 16:50:18 | 显示全部楼层
顶顶更健康!!!
http://bbs.yzwlo.com 晓枫资讯--游戏IT新闻资讯~~~
严禁发布广告,淫秽、色情、赌博、暴力、凶杀、恐怖、间谍及其他违反国家法律法规的内容。!晓枫资讯-社区
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

1楼
2楼
3楼
4楼

手机版|晓枫资讯--科技资讯社区 本站已运行

CopyRight © 2022-2025 晓枫资讯--科技资讯社区 ( BBS.yzwlo.com ) . All Rights Reserved .

晓枫资讯--科技资讯社区

本站内容由用户自主分享和转载自互联网,转载目的在于传递更多信息,并不代表本网赞同其观点和对其真实性负责。

如有侵权、违反国家法律政策行为,请联系我们,我们会第一时间及时清除和处理! 举报反馈邮箱:点击这里给我发消息

Powered by Discuz! X3.5

快速回复 返回顶部 返回列表