五指棋逻辑, 简单实现

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;
}

扫描二维码关注公众号,回复: 3256018 查看本文章

猜你喜欢

转载自blog.csdn.net/insist_07/article/details/82660077