我是靠谱客的博主 单薄大门,最近开发中收集的这篇文章主要介绍基于C语言实现五子棋游戏,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

采用二维数组制作五子棋,用坐标下棋。

请看代码。

include<stdio.h>
#include<string.h>
#include<stdlib.h>
#include<windows.h>
#include<conio.h>
#include<time.h>
 
void menu()//目录
{
 char xuanze = 0,xuanze2;
 printf("n");
 printf("n");
 printf("       #############################################n");
 printf("           *五子棋小游戏*n");
 printf("           *1.双人游戏*n");
 printf("           *2.人机对战(暂未开放)n");
 printf("           *3.游戏须知n");
 printf("       #############################################n");
 printf("          请选择选项,目前仅有 1 选项n");
 printf("n");
 printf("           ");
 xuanze = _getch();
 switch (xuanze)
 {
 case 1:
 break;
 case 3:
 printf("本游戏是键盘输入坐标来落子的,白棋先落,第二次落子为黑色,依次落子。n");
 printf("若落子坐标非法则需重新落子。n");
 printf("键盘输入1直接进入游戏n");
 
 }
}
int t = 2;
int pan[20][20] =
{
 {1,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,3},
 {4,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,6},
 {4,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,6},
 {4,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,6},
 {4,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,6},
 {4,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,6},
 {4,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,6},
 {4,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,6},
 {4,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,6},
 {4,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,6},
 {4,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,6},
 {4,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,6},
 {4,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,6},
 {4,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,6},
 {4,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,6},
 {4,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,6},
 {4,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,6},
 {4,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,6},
 {4,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,5,6},
 {7,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,8,9}
};
void qp()//棋盘
{
 int i, j, k = 0;
 printf(" ");
 for (i = 0; i < 10; i++)
 printf(" %d", i + 1);
 for (i = 10; i < 20; i++)
 printf("%d", i + 1);
 printf("n");
 printf("1 ");
 //printf("┌ ┬ ┐├ ┼ ┤└ ┴ ┘│ ");©○●┼
 for (i = 0; i < 20; i++)
 for (j = 0; j < 20; j++)
 {
 switch (pan[i][j])
 {
 case 1:
 printf("┌ ");
 k++;
 if (k % 20 == 0)
 {
  printf("n");
 }  
 break;
 case 2:
 printf("┬ ");
 k++;
 if (k % 20 == 0)
  printf("n");
 break;
 case 3:
 printf("┐ ");
 k++;
 if (k % 20 == 0)
 {
  printf("%d", i+1);
  printf("n");
  printf("%d ", i + 1);
 }
 break;
 case 4:
 printf("├ ");
 k++;
 if (k % 20 == 0)
  printf("n");
 break;
 case 5:
 printf("┼ ");
 k++;
 if (k % 20 == 0)
  printf("n");
 break;
 case 6:
 printf("┤ ");
 k++;
 if (k % 20 == 0)
 {
  printf("%d", i+1);
  printf("n");
  if(i<8)
  printf("%d ", i + 2);
  if(i>7)
  printf("%d", i + 2);
 }  
 break;
 case 7:
 printf("└ ");
 k++;
 if (k % 20 == 0)
  printf("n");
 break;
 case 8:
 printf("┴ ");
 k++;
 if (k % 20 == 0)
  printf("n");
 break;
 case 9:
 printf("┘ ");
 k++;
 if (k % 20 == 0)
 {
  printf("%d", i + 1);
  printf("n");  
 }  
 break;
 case 10:
 printf("○");
 k++;
 if (k % 20 == 0)
 {
  printf("%d", i+1);
  printf("n");
 } 
 break;
 case 11:
 printf("●");
 k++;
 if (k % 20 == 0)
 {
  printf("%d", i+1);
  printf("n");
 } 
 break;
 }
 }
 printf(" ");
 for (i = 0; i < 10; i++)
 printf(" %d", i + 1);
 for (i = 10; i < 20; i++)
 printf("%d", i + 1);
 printf("n");
 printf("n");
}
void play()
{
 int i, j;
 while (1)
 {
 printf("*请选择落子坐标(x,y): ");
 scanf_s("%d %d", &j, &i);
 printf("n");
 if(i>0&&i<21&&j>0&&j<21)
 {
 if (pan[i - 1][j - 1] != 10 && pan[i - 1][j - 1] != 11)
 {
  if (t % 2 == 1)
  {
  t++;
  pan[i - 1][j - 1] = 11;
  break;
  }
  else if (t % 2 == 0)
  {
  t++;
  pan[i - 1][j - 1] = 10;  
  break;
  }
 }
 else if (pan[i-1][j-1] == 10 || pan[i-1][j-1] == 11)
 {
  printf("此处已经有棋子,请重新输入n");
  continue;
 }
 } 
 else if (i < 1 || i > 21 || j < 1 || j > 21)
 {
 printf("坐标不合法,请重新输入n");
 continue;
 }
 } 
}
void test()
{
 int i, j;
 for(i=0;i<20;i++)
 for (j = 0; j < 20; j++)
 {
 if (pan[i][j] != 1 || 2 || 3 || 4 || 5 || 6 || 7 || 8 || 9)
 {
 if (pan[i][j] == pan[i][j + 1]&&pan[i][j] == pan[i][j + 2]&&pan[i][j] == pan[i][j + 3]&&pan[i][j] == pan[i][j + 4])
 {
  if (pan[i][j] == 11)
  {
  printf("白棋获胜n");  
  }  
  if (pan[i][j] == 10)
  {
  printf("黑棋获胜n");  
  }  
 }
 if (pan[i][j] == pan[i + 1][j]&&pan[i][j] == pan[i + 2][j]&&pan[i][j] == pan[i + 3][j]&&pan[i][j] == pan[i + 4][j])
 {
  if (pan[i][j] == 11)
  {
  printf("白棋获胜n");  
  }  
  if (pan[i][j] == 10)
  {
  printf("黑棋获胜n");  
  }  
 }
 if (pan[i][j] == pan[i + 1][j + 1]&&pan[i][j] == pan[i + 2][j + 2]&&pan[i][j] == pan[i + 3][j + 3] &&pan[i][j]== pan[i + 4][j + 4])
 {
  if (pan[i][j] == 11)
  {
  printf("白棋获胜n");  
  }  
  if (pan[i][j] == 10)
  {
  printf("黑棋获胜n");  
  }  
 }
 if (pan[i][j] == pan[i - 1][j + 1]&&pan[i][j] == pan[i - 2][j + 2] &&pan[i][j]== pan[i - 3][j + 3]&&pan[i][j] == pan[i - 4][j + 4])
 {
  if (pan[i][j] == 11)
  {
  printf("白棋获胜n");  
  }  
  if (pan[i][j] == 10)
  {
  printf("黑棋获胜n");  
  } 
 }
 }
 }
}
int main()
{
 system("mode con cols=98 lines=48");
 SetConsoleTitleA("五子棋小游戏"); //设置窗口
 menu();
 system("cls");
 while (1)
 {
 qp();
 test(); 
 play();
 system("cls");
 }
 system("pause");
 return 0;
}

更多有趣的经典小游戏实现专题,分享给大家:

C++经典小游戏汇总

python经典小游戏汇总

python俄罗斯方块游戏集合

JavaScript经典游戏 玩不停

java经典小游戏汇总

javascript经典小游戏汇总

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

最后

以上就是单薄大门为你收集整理的基于C语言实现五子棋游戏的全部内容,希望文章能够帮你解决基于C语言实现五子棋游戏所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(104)

评论列表共有 0 条评论

立即
投稿
返回
顶部