简单的五子棋程序(可悔棋版和普通版)

news/2024/10/17 18:20:42/

//普通版

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <windows.h>
#define N  8
void display(char (* p)[N])
{
     system("cls");
    int i,j;
    for(i=0; i<N; i++)
    {
        for(j=0; j<N; j++)
        {
            printf("%c\t",p[i][j]);
        }
        printf("\n\n\n");
    }
}
void  downchess(char (* p)[N])
{
    char black='#';
    char white='@';
    char h;
    int i,j,num=0;
    do
    {
        if(num%2==0)
        {
            h=black;
        }
        else
        {
            h=white;
        }
        printf("%c方请输入落子坐标的行和列:",h);
        scanf("%d%d",&i,&j);
        if (p[i][j]!='.')continue;
        p[i][j]=h;
        display(p);
//        if(judje(p,i,j)==1)
//        {
//
//            break;
//        }
        num++;
    }
    while(judje(p,i,j)==0);
       printf("%c方胜利\n",h);
}
int  judje(char (* p)[N],int a,int b)
{
    int sum=0;
    int j=0,i=1;
//判断行向
    for(;;)
    {
        if(p[a][b-j]==p[a][b])
        {
            sum++;
            j++;
        }
        else if(p[a][b+i]==p[a][b])
        {
            sum++;
            i++;
        }
        else
            break;
    }
      if(sum==5)
        return  1;
 //判断纵向
     sum=0;j=0;i=1;
  for(;;)
    {
        if(p[a-j][b]==p[a][b])
        {
            sum++;
            j++;
        }
        else
        if(p[a+i][b]==p[a][b])
        {
            sum++;
            i++;
        }
        else break;
    }
     if(sum==5)
    return  1;
//判断右对角
  sum=0;j=0;i=1;
  for(;;)
    {
        if(p[a-j][b+j]==p[a][b])
        {
            sum++;
            j++;
        }
        else
       if(p[a+i][b-i]==p[a][b])
        {
            sum++;
            i++;
        }
        else break;
    }
     if(sum==5)
    return  1;
    sum=0;j=0;i=1;
 // 判断左对角
  for(;;)
    {
        if(p[a+j][b+j]==p[a][b])
        {
            sum++;
            j++;
        }
        else
       if(p[a-i][b-i]==p[a][b])
        {
            sum++;
            i++;
        }
        else break;
    }
     if(sum==5)
    return  1;
      else return 0;
}
int main()
{
    int i,j;
    char chess[N][N];
    int n=48,k=49;
    for(i=0; i<N; i++)
    {
        for(j=0; j<N; j++)
        {
            if(i==0)
            {
                chess[i][j]=n;
                n++;
            }
            else if(j==0)
            {
                chess[i][j]=k;
                k++;
            }
            else
                chess[i][j]='.';
        }
    }
    display(chess);
    downchess(chess);
    return 0;
}


//可悔棋版

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <windows.h>
#define N  8
void display(int (* p)[N])
{
     system("cls");
    int i,j;
    char qipan[N][N];
    char black='#';
    char white='@';
    char null='.';


    for(i=0; i<N; i++)
    {
        for(j=0; j<N; j++)
        {
        if(p[i][j]%2==0)
                qipan[i][j]=black;
            else  if(p[i][j]%2==1)
                qipan[i][j]=white;
              else qipan[i][j]=null;
        }
}
    for(i=-1; i<N; i++)
    {
        printf("%d\t",i);
    }   printf("\n\n\n");
    for(i=0; i<N; i++)
    {
        printf("%d\t",i);
        for(j=0; j<N; j++)
        {
            printf("%c\t",qipan[i][j]);
        }
        printf("\n\n\n");
    }
}
void  downchess(int (* p)[N])
{
     char h;
     char black='#';
     char white='@';
    int i,j,num=0;


    do
    {
        if(num%2==0)
        {
            h=black;
        }
        else
        {
            h=white;
        }
        printf("%c方请输入落子坐标的行和列:",h);
        scanf("%d%d",&i,&j);
        if (p[i][j]!=-1)continue;
        p[i][j]=num;
        display(p);
         int  choose;
       do
         {
            printf("悔棋请按2,继续请按1:");


          scanf("%d",&choose);
        switch(choose)
           {
           case  1:     break;
           case  2:
               huiqi(p,num);
               num--;
               display(p);
           default :    break;
           }


         }while(choose!=1);
        num++;
    }
    while(judje(p,i,j,num-1)==0);
       printf("%c方胜利\n",h);
}
void  huiqi(int (* p)[N],int num)
{
    int i,j;
    for(i=0;i<N;i++)
        {
            for(j=0;j<N;j++)
    {
        if(p[i][j]==num)
            p[i][j]=-1;
    }
        }


}




int  judje(int (* p)[N],int a,int b,int num)
{
    int sum=0;
    int j=0,i=1;
//判断行向
    for(;;)
    {
        if(p[a][b-j]%2==num%2&&p[a][b-j]!=-1)
        {
            sum++;
            j++;
        }
        else if(p[a][b+i]%2==num%2&&p[a][b+i]!=-1)
        {
            sum++;
            i++;
        }
        else
            break;
    }
      if(sum==5)
        return  1;
 //判断纵向
     sum=0;j=0;i=1;
  for(;;)
    {
        if(p[a-j][b]%2==num%2&&p[a-j][b]!=-1)
        {
            sum++;
            j++;
        }
        else
        if(p[a+i][b]%2==p[a][b]%2&&p[a+i][b]!=-1)
        {
            sum++;
            i++;
        }
        else break;
    }
     if(sum==5)
    return  1;
//判断右对角
  sum=0;j=0;i=1;
  for(;;)
    {
        if(p[a-j][b+j]%2==num%2&&p[a-j][b+j]!=-1)
        {
            sum++;
            j++;
        }
        else
       if(p[a+i][b-i]%2==num%2&&p[a+i][b-i]!=-1)
        {
            sum++;
            i++;
        }
        else break;
    }
     if(sum==5)
    return  1;
    sum=0;j=0;i=1;
 // 判断左对角
  for(;;)
    {
        if(p[a+j][b+j]%2==num%2&&p[a+j][b+j]!=-1)
        {
            sum++;
            j++;
        }
        else
       if(p[a-i][b-i]%2==num%2&&p[a-i][b-i]!=-1)
        {
            sum++;
            i++;
        }
        else break;
    }
     if(sum==5)
    return  1;
      else return 0;
}
int main()
{
    int i,j;
    int  chess[N][N];
    for(i=0; i<N; i++)
    {
        for(j=0; j<N; j++)
        {
                chess[i][j]=-1;
        }
    }
    display(chess);
    downchess(chess);
    return 0;
}


http://www.ppmy.cn/news/563055.html

相关文章

五子棋网页版

基于js的五子棋教程 先给出问题&#xff0c;然后一步一步的去解决&#xff1b; 需要的知识&#xff1a;html,css,js基础语法&#xff0c;包括创建对象和继承属性&#xff1b;需要的知识很少&#xff0c;就是js的创建对象&#xff0c;如果不会就去看一下书吧。整个js都是基于一…

C++畅玩五子棋项目

畅玩五子棋项目说明 ​ 项目创建环境&#xff1a;Windows 10 Visual Studio 2019 ​ 棋子类型&#xff1a;实心●和空心◎。其中&#xff0c;棋子彩色棋子为当前落子 ​ 实现功能&#xff1a;对战模式&#xff08;人人对战&#xff09;、人机模式&#xff08;人机模式&…

基于C++的五子棋项目

一、五子棋项目介绍 1.游戏规则 五子棋是我国古代传统的黑白棋种之一&#xff0c;黑白双方依次落子&#xff0c;任意一方在棋盘上形成横向、纵向、斜向的连续相同颜色的五颗棋子的一方为胜。 2.完成界面显示 此次项目将不使用任何图形库进行开发&#xff0c;所有显示的内容都…

五子棋的设计与实现

术&#xff1a;Java等 摘要&#xff1a; 五子棋是一种两人对弈的纯策略型棋类游戏&#xff0c;非常容易上手&#xff0c;老少皆宜。为了更好的推广五子棋&#xff0c;研究简单的人工智能方式&#xff0c;运用Java开发五子棋游戏。主要包含了人机对战&#xff0c;棋盘初始化&…

五子棋-完美解决闪屏问题版-新增悔棋功能(C++实现)

在学C的时候&#xff0c;在做课设的时候做了一个五子棋课设&#xff0c;当时选这个就是觉得挺好玩的&#xff0c;想理解一下游戏是如何实现的&#xff0c;然后就入了这个坑。。。这个我没有用图形化界面来实现&#xff0c;完全是使用字符来实现。然后没有用图形化界面的最大的问…

C++、easyx组合的界面版五子棋(适合新手)

C、easyx组合的五子棋界面版&#xff08;适合新手&#xff09; 点击进入五子棋控制台版本 文章目录 C、easyx组合的五子棋界面版&#xff08;适合新手&#xff09;前言效果图一、游戏规则二、实现逻辑1.绘制棋盘2.落子2.1 鼠标坐标的获取2.2 绘制棋子 三、输赢判定算法四、其…

Windows编程 简易五子棋

简易五子棋&#xff0c;望指正 #include <windows.h> #include<commctrl.h> #define SIZE 20 UINT IDC_BUTTON1200; HWND hwnd; HPEN penbackCreatePen(PS_SOLID,1,RGB(0,0,0)); HPEN penback2CreatePen(PS_SOLID,1,RGB(255,255,255)); HBRUSH brushbackCreateSo…

课程设计-单机版五子棋游戏-Java

一. 项目简介&#xff1a; 五子棋是全国智力运动会竞技项目之一&#xff0c;是一种两人对弈的纯策略型棋类游戏。五子棋的玩法是&#xff1a;双方分别使用黑白两色的棋子&#xff0c;下在棋盘直线与横线的交叉点上&#xff0c;先形成五子连线者获胜。五子棋的棋具与围棋通用…