gpt4 book ai didi

C语言版五子棋游戏的实现代码

转载 作者:qq735679552 更新时间:2022-09-27 22:32:09 25 4
gpt4 key购买 nike

CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.

这篇CFSDN的博客文章C语言版五子棋游戏的实现代码由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.

这次看了几位大佬的做法,我们也做了很多修改尝试。算是第一次尝试合作完成项目.

我认为学到的东西:

1、第一次尝试写项目,把函数分到不同的.c文件中后更好看了一些。 2、在研究过程中应该分清主次。代码正确运行才是基础要求,其他什么美化界面,调字体调颜色都并非重点。 3、从代码中学到的,①是采用落子数来判断该轮到黑方下还是白方下(落子数为2的倍数时黑方下,否则白方下),这样也能判断出是哪一方胜利,而且落子数还可以判断棋盘是否下满(==16*16时棋盘落满,平局) ②是胜利条件的判断,以中间子为参考,看两边的四个子是否和他颜色相同.

规则

在一个1616的棋盘上,黑白双方交替落子,每次落下子后如果棋盘上出现了五个同色棋子横向/竖向/斜向连接,则该方胜利。如果在棋盘下满后(即下了1616个子后)仍未分出胜负,则为平局.

逻辑

初始化棋盘,是一个16*16的二维数组(定义宏 N=16),一开始每一格都初始化为0。用一个不断++的落子数变量%2来判断本回合是黑方下还是白方下,;每次玩家输入横纵坐标,该处的变量值改变(黑子为1,白子为2)。每次落子判断全盘是否有五子连珠,如果有则结束游戏,如果没有则继续下。当落子数达到N*N即棋盘下满,还没有出现五子连珠时,则判断为平局,结束游戏.

五子棋胜负条件判断

判断原理

胜负的判断是在每颗棋子落下之后进行,所以用这一子的坐标为基准前后左右斜各个方向来看是否取胜.

具体思想

按照五子棋规则,当一方的棋子,在横向,纵向或斜向连续五个均为同一用户的棋子时,代表胜利。 另外,胜利判断只需要在一个新子落子时判断,且仅需要判断新子所在的四条线上(纵横加两个斜线)是否满足条件即可。 所以,可以以新子坐标为基准点,判断四次。 比如横向的,需要判断左侧和右侧连续的同类棋子个数,如果左侧+右侧+1(自身)总数>=5,则为胜利。 在判断胜利的时候,首先我们要排除空子的情况,然后当两个斜线的时候, 无胜情况下,判断直线,当为两斜线及直线无胜情况下,判断横线.

参考代码如下:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
int win()
{
  extern int arr[100][100];
  int k = 0,l = 0;
  int flag = 0;
  for (k=2;k<N-2;k++)
   for (l=2;l<N-2;l++)
   {
    if (arr[k][l]!=0&&arr[k-2][l-2]==arr[k][l]&&arr[k-1][l-1]==arr[k][l]&&arr[k+1][l+1]==arr[k][l]&&arr[k+2][l+2]==arr[k][l])
    {
     flag=1;
     break ;
    }
    if (arr[k][l]!=0&&arr[k+2][l-2]==arr[k][l]&&arr[k+1][l-1]==arr[k][l]&&arr[k-1][l+1]==arr[k][l]&&arr[k-2][l+2]==arr[k][l])
    {
     flag=1;
     break ;
    }
   }
  if (flag==0)
   for (k=0;k<N;k++)
    for (l=2;l<N-2;l++)
    {
     if (arr[k][l]!=0&&arr[k][l-2]==arr[k][l]&&arr[k][l-1]==arr[k][l]&&arr[k][l+1]==arr[k][l]&&arr[k][l+2]==arr[k][l])
     {
      flag=1;
      break ;
     }
    }
  if (flag==0)
   for (k=2;k<N-2;k++)
    for (l=0;l<N;l++)
    {
     if (arr[k][l]!=0&&arr[k+2][l]==arr[k][l]&&arr[k+1][l]==arr[k][l]&&arr[k-1][l]==arr[k][l]&&arr[k-2][l]==arr[k][l])
     {
      flag=1;
      break ;
     }
    }
  return flag;
}

1.中的arr[k][l]!=0是排除空子的情况。 2.最后返回判断结果时, 有胜为1,无为0,谁胜无必要判断,因为,谁尾手了的一定是胜的.

演示

开始 。

C语言版五子棋游戏的实现代码

输入坐标 。

C语言版五子棋游戏的实现代码

第二回合 。

C语言版五子棋游戏的实现代码

游戏结束 。

C语言版五子棋游戏的实现代码

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

原文链接:https://blog.csdn.net/jtwqwq/article/details/119067784 。

最后此篇关于C语言版五子棋游戏的实现代码的文章就讲到这里了,如果你想了解更多关于C语言版五子棋游戏的实现代码的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com