C语言实现双人五子棋游戏

 更新时间:2021年06月06日 09:49:34   作者:两片空白  
这篇文章主要为大家详细介绍了C语言实现双人五子棋游戏,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

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

实现功能

生成棋盘玩家1与玩家2对战,哪个玩家率先有连续5子连线,哪个玩家赢。

如何实现

组成:

二维数组:board[ROW][COL],定义一个ROW*COL的棋盘。

主要逻辑:

显示棋盘,提示用户下子,下子后判断

1.显示棋盘很简单,慢慢凑棋盘就好
2. 用户下子,注意两个条件:棋子在棋盘里,下子位置未被占用。
3.判断是最难的,

方法:从下子位置的8个方向(上,下,左,右,右上,右下,左上,左下)计算相同棋子数目,然后将对角的棋子数相加,等于5说明有5子连线

主要函数中用到三个主要实现函数:

Showboard(board, ROW, COL);//展示棋盘
Playermove(board, ROW, COL, cur);//玩家下注,cur表示哪个玩家下子
Judge(board, ROW, COL);//判断5子连线
Getcount(board[][COL], row, col, dir)//计算方向dir相同棋子数

代码

头文件

#ifndef __FIVECHREE_H__
#define __FIVECHEE_H__


#include<stdio.h>
#include<windows.h>
#pragma warning(disable:4996)

#define ROW 10//棋盘行数
#define COL 10//棋盘列数
#define INIT '*'//棋盘初始化

#define PLAYER1 1
#define PLAYER2 2
#define NEXT 3//继续往下下
#define DRAW 4//棋盘下满 平局

//8个方向
#define UP 10
#define RIGHT_UP 11
#define RIGHT 12
#define RIGHT_DOWN 13
#define DOWN 14
#define LEFT_DOWN 15
#define LEFT 16
#define LEFT_UP 17

extern void Menu();
extern void Game();

#endif

main函数源文件

#include"fivechree.h"
int main(){
 int quit = 0;
 while (!quit){
  Menu();
  int select = 0;
  scanf("%d", &select);
  switch (select){
  case 1:
   Game();
   break;
  case 2:
   quit = 1;
   break;
  default:
   printf("Enter Error!\n");
   break;
   
  }

 }
 printf("Byebye\n");
 system("pause");
 return 0;
}

函数定义源文件

#include"fivechree.h"

static int x = 0;
static int y = 0;

void Menu(){
 printf("+---------------------+\n");
 printf("+- 1.Play    2.Exit  -+\n");
 printf("+---------------------+\n");
 printf("Please Enter Your Select#");

}
static void Showboard(int board[][COL], int row, int col){//展示棋盘 o玩家1棋子,x玩家2棋子
 system("cls");
 for (int i = 0; i < row; i++){
  for (int j = 0; j < col; j++){
   switch (board[i][j]){
   case PLAYER1:
    board[i][j] = 'o';
    break;
   case PLAYER2:
    board[i][j] = 'x';
    break;
   case 0:
    board[i][j] = INIT;
    break;
   default:
    break;
   }
  }
 }
 printf("  ");
 for (int i =1; i <= row; i++){
  printf("%2d ", i);
 }
 printf("\n");
 for (int i = 1; i <= row; i++){
  printf("%-2d", i);
  for (int j = 1; j <= col; j++){
   printf(" %c ", board[i - 1][j - 1]);
  }
  printf("\n");
 }
}

static void Playermove(int board[][COL], int row, int col, int who){//玩家下子,who 为哪个玩家下子
 while (1){
  printf("Please Enter PLAYER%d Postion<x,y>#", who);
  scanf("%d %d", &x, &y);
  if (x<1 || x>row || y<1 || y>col){  //超过棋盘范围
   printf("Postion is error!\n");
   continue;
  }
  if (board[x - 1][y - 1] == INIT){//判断位置是否已被下子
   board[x - 1][y - 1] = who;
   break;
  }
  printf("Postion is not empty\n");
 }

}

static int Getcount(int board[][COL], int row, int col, int dir){//判断8个方向相同棋子的数目
 int _x = x;//_x,_y变化,后面与x,y棋子相比较
 int _y = y;
 int count = 0;
 while (1){
  switch (dir){
  case UP:
   _x--;
   break;
  case DOWN:
   _x++;
   break;
  case LEFT:
   _y--;
   break;
  case RIGHT:
   _y++;
   break;
  case RIGHT_UP:
   _x--, _y++;
   break;
  case RIGHT_DOWN:
   _x++, _y++;
   break;
  case LEFT_DOWN:
   _x++, _y--;
   break;
  case LEFT_UP:
   _x--, _y--;
   break;
  default:
   break;
  }
  if (_x>=1 || _x<=row || _y>=1 || _y<=col){//棋子不能越界
   if (board[x-1][y-1] == board[_x-1][_y-1]){
    //printf("yes\n");
    count++;
   }
   else{
    //printf("no\n");
    break;
   }
  }
  else{
   return count;
  }
  
 }
 return count;
}
//如何判断:从下子位置的8个方向(上,下,左,右,右上,右下,左上,左下)
//计算相同棋子数目,然后将对角的棋子数相加,等于5说明有5子连线
static int Judge(int board[][COL], int row, int col){
 int count1 = Getcount(board, row, col, UP)\
  + Getcount(board, row, col, DOWN);
 //printf("%d\n", count1);
 if (count1 >= 4){
  return board[x-1][y-1];
 }
 count1 = Getcount(board, row, col, RIGHT_UP)\
  + Getcount(board, row, col, LEFT_DOWN);
 //printf("%d\n", count1);
 if (count1 >= 4){
  return board[x-1][y-1];
 }
 count1 = Getcount(board, row, col, RIGHT)\
  + Getcount(board, row, col, LEFT);
 //printf("%d\n", count1);
 if (count1 >= 4){
  return board[x-1][y-1];
 }
 count1 = Getcount(board, row, col, RIGHT_DOWN)\
  + Getcount(board, row, col, LEFT_UP);
 if (count1 >= 4){
  return board[x-1][y-1];
 }

 for (int i = 0; i < row; i++){//判断棋盘是否下满
  for (int j = 0; j < col; j++){
   if (board[i][j] == INIT){
    return NEXT;
   }
  }
 }
 return DRAW;
}


void Game(){
 int board[ROW][COL] = { 0 };
 //memset(board, INIT, ROW*COL);
 int result = 0;
 int cur = PLAYER1;
 Showboard(board, ROW, COL);//先展示棋盘
 while (1){
  //Showboard(board, ROW, COL);
  Playermove(board, ROW, COL, cur);
  Showboard(board, ROW, COL);//棋盘将board数组变化,所以要在判断前将数组变化
  result = Judge(board, ROW, COL);
  if (result != NEXT){
   break;
  }
  cur = (cur == PLAYER1 ? PLAYER2 : PLAYER1);//三目表达式,注意不是 PLAYER1 ? PLAYER2 : PLAYER1
 }

 Showboard(board, ROW, COL);
 switch (result){
 case 'o':
  printf("Player1 Win!\n");
  break;
 case 'x':
  printf("Player2 Win!\n");
  break;
 case DRAW:
  printf("Tie Game!\n");
  break;
 default:
  //printf("%c\n", result);
  printf("BUG\n");
  break;
 }
}

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

相关文章

  • C语言中的字符型数据与ASCII码表

    C语言中的字符型数据与ASCII码表

    这篇文章主要介绍了C语言中的字符型数据与ASCII码表,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-01-01
  • C++实现无重复字符的最长子串

    C++实现无重复字符的最长子串

    本文主要介绍了C++实现无重复字符的最长子串,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-07-07
  • 看图深入理解单链表的反转

    看图深入理解单链表的反转

    今天遇到单向链表的反转的问题,于是静下心来好好想了一番。下面这篇文章主要给大家介绍了关于单链表反转的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-02-02
  • VS及Unity安装和使用Nuget包

    VS及Unity安装和使用Nuget包

    本文主要介绍了VS及Unity安装和使用Nuget包,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-01-01
  • 详解C++编程中类模板的相关使用知识

    详解C++编程中类模板的相关使用知识

    这篇文章主要介绍了详解C++编程中类模板的相关使用知识,包括函数的参数类型替换等方法,需要的朋友可以参考下
    2015-09-09
  • c++核心编程之函数的重载

    c++核心编程之函数的重载

    这篇文章主要介绍了c++核心编程之函数的重载,函数可以重复使用,提高了复用性,但前提是必须在一个作用域并且函数名称相同,下面附代码详细介绍,需要的小伙伴可以参考一下
    2022-03-03
  • 关于在C程序中处理UTF-8文本的方法详解

    关于在C程序中处理UTF-8文本的方法详解

    这篇文章主要给大家介绍了关于在C程序中处理UTF-8文本的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面来一起看看吧。
    2017-11-11
  • C++实现LeetCode(152.求最大子数组乘积)

    C++实现LeetCode(152.求最大子数组乘积)

    这篇文章主要介绍了C++实现LeetCode(152.求最大子数组乘积),本篇文章通过简要的案例,讲解了该项技术的了解与使用,以下就是详细内容,需要的朋友可以参考下
    2021-07-07
  • C++中多线程的执行顺序如你预期吗

    C++中多线程的执行顺序如你预期吗

    这篇文章主要为大家详细介绍一下C++中多线程的执行顺序的相关资料,文中的示例代码讲解详细,对我们学习C++多线程有一定帮助,需要的可以参考一下
    2022-10-10
  • Visual Studio2022的完全卸载及安装到D盘的操作方法

    Visual Studio2022的完全卸载及安装到D盘的操作方法

    这篇文章主要介绍了Visual Studio2022的完全卸载以及完全安装到D盘,因为VS如果随便写在会有很多很多的乱七八糟的东西掉出来,所以我们选择制式一点的卸载方式,需要的朋友可以参考下
    2022-09-09

最新评论