五指棋逻辑, 简单实现

include”stdio.h”

include”windows.h”

include”stdlib.h”

include”conio.h”

void initqipan();//初始化棋盘
void printqipan();//打印棋盘
void pos(int x,int y);
void xiaqi();
int tonji (int x,int y);
void win();//胜利判断
void zhuobiao();//
void white();//
void black();
char qipan[20][20];
int x,y;
int i,j;

void pos(int x,int y)//句柄
{
COORD pos;
HANDLE h0utput;
pos.X=x;
pos.Y=y;
h0utput=GetStdHandle(STD_OUTPUT_HANDLE);
SetConsoleCursorPosition(h0utput,pos);
}
void initqipan()
{
for(i=0;i<20;i++)
for(j=0;j<20;j++)
qipan[i][j]=’*’;
}

void printqipan()
{

for(i=0;i<20;i++)
{   zhuobiao();
    pos(30,5+i);//从此坐标开始显示,并起到换行的作用
    for(j=0;j<20;j++)
printf("%-2c",qipan[i][j]);

}

}

int tonji (int x,int y)//统计连成五子
{
int WhoWin=0;
char temp;
temp=qipan[x][y];
int i=1;
int count=1; //统计练成的个数
while(temp==qipan[x+i][y]&&x>0&&x<20&&y>0&&y<19&&count<5)//判断垂直连成五子
{
i++;
count++;
if(count==5)
{
if(temp==’S’)
WhoWin=1;
else
WhoWin=2;
}
}
i=1;
while(temp==qipan[x-i][y]&&x>0&&x<20&&y>0&&y<19&&count<5)
{
i++;
count++;
if(count==5)
{
if(temp==’S’)
WhoWin=1;
else
WhoWin=2;
}
}
i=1;
while(temp==qipan[x][y+i]&&x>0&&x<20&&y>0&&y<19&&count<5) //判断水平连成五子
{
i++;
count++;
if(count==5)
{
if(temp==’S’)
WhoWin=1;
else
WhoWin=2;
}

}
i=1;
while(temp==qipan[x][y-i]&&x>0&&x<20&&y>0&&y<19&&count<5)
{
    i++;
    count++;    
        if(count==5)
        {
            if(temp=='S')
                WhoWin=1;
            else
                WhoWin=2;
        }   
}
    i=1;        
while(temp==qipan[x+i][y-i]&&x>0&&x<20&&y>0&&y<19&&count<5)     //判断右对角线连成五子     右下
{
    i++;
    count++;    
        if(count==5)
        {
            if(temp=='S')
                WhoWin=1;
            else
                WhoWin=2;
        }   
}
i=1;
while(temp==qipan[x-i][y+i]&&x>0&&x<20&&y>0&&y<19&&count<5)//右上
{
    i++;
    count++;    
        if(count==5)
        {
            if(temp=='S')
                WhoWin=1;
            else
                WhoWin=2;
        }   
}
i=1;        
while(temp==qipan[x-i][y-i]&&x>0&&x<20&&y>0&&y<19&&count<5)     //判断左对角线连成五子     左上
{
    i++;
    count++;    
        if(count==5)
        {
            if(temp=='S')
                WhoWin=1;
            else
                WhoWin=2;
        }       
}
i=1;
while(temp==qipan[x+i][y+i]&&x>0&&x<20&&y>0&&y<19&&count<5)//左下
{
    i++;
    count++;    
        if(count==5)
        {
            if(temp=='S')
                WhoWin=1;
            else
                WhoWin=2;
        }   
}
return WhoWin;

}
void win()
{
int leap;
leap=tonji (x,y);
if(leap==1)
printf(“白棋赢!”);
if(leap==2)
printf(“黑棋赢!”);
}

void zhuobiao()//坐标的显示
{
int i;
pos(30,4);
for(i=0;i<20;i++)
printf(“%-2d”,i);
for(i=0;i<20;i++)
{
pos(27,5+i);
printf(“%2d”,i);
}
}
void white()
{
printf(“白方下棋输入坐标:”);
scanf(“%d%d”,&x,&y);
while(1)
{
if(qipan[x][y]==’*’)
{
qipan[x][y]=’S’;

        break;
    }
    else
    {
    printf("请重新输入:");
    printf("白方下棋输入坐标:");

    }
    scanf("%d%d",&x,&y); 

}
printqipan();

system("cls");   //清理屏幕

win();
    printqipan();

}
void black()
{printf(“黑方下棋输入坐标:”);
scanf(“%d%d”,&x,&y);
while(1)
{
if(qipan[x][y]==’*’)
{
qipan[x][y]=’Y’;

        break;
    }
    else
    {
    printf("请重新输入:");
    printf("黑方下棋输入坐标:");    
    }
    scanf("%d%d",&x,&y); 

}
printqipan();

system("cls");   //清理屏幕

win();
printqipan();

}
void xiaqi()
{
initqipan();
printqipan();

while(1)
{
black();
white();
}
}

int main()
{
xiaqi();
return 0;
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值