首页 > 其他分享 >五子棋(可判断输赢)

五子棋(可判断输赢)

时间:2023-11-05 10:12:05浏览次数:29  
标签:判断 f5 16 int win 五子棋 else && 输赢

#include <iostream>
#include <iomanip>
using namespace std;
int row=16;
int col=16;
int all[17][17];
bool black=true;
bool whilt;
int x,y;
int a=1;
int t=0;
int e=0;
bool win(){
    int l=all[x][y];
    if(all[x][y-1]==l&&all[x][y-2]==l&&all[x][y-3]==l&&all[x][y-4]==l){
        e=1;
    }else if(all[x][y-1]==l&&all[x][y-2]==l&&all[x][y-3]==l&&all[x][y+1]==l){
        e=1;
    }else if(all[x][y-1]==l&&all[x][y-2]==l&&all[x][y+1]==l&&all[x][y+2]==l){
        e=1;
    }else if(all[x][y-1]==l&&all[x][y+1]==l&&all[x][y+2]==l&&all[x][y+3]==l){
        e=1;
    }else if(all[x][y+1]==l&&all[x][y+2]==l&&all[x][y+3]==l&&all[x][y+4]==l){
        e=1;
    }else if(all[x-1][y]==l&&all[x-2][y]==l&&all[x-3][y]==l&&all[x-4][y]==l){
        e=1;
    }else if(all[x-1][y]==l&&all[x-2][y]==l&&all[x-3][y]==l&&all[x+1][y]==l){
        e=1;
    }else if(all[x-1][y]==l&&all[x-2][y]==l&&all[x+2][y]==l&&all[x+1][y]==l){
        e=1;
    }else if(all[x-1][y]==l&&all[x+3][y]==l&&all[x+2][y]==l&&all[x+1][y]==l){
        e=1;
    }else if(all[x+4][y]==l&&all[x+3][y]==l&&all[x+2][y]==l&&all[x+1][y]==l){
        e=1;
    }else if(all[x+1][y-1]==l&&all[x+2][y-2]==l&&all[x+3][y-3]==l&&all[x+4][y-4]==l){
        e=1;
    }else if(all[x+1][y-1]==l&&all[x+2][y-2]==l&&all[x+3][y-3]==l&&all[x-1][y+1]==l){
        e=1;
    }else if(all[x+1][y-1]==l&&all[x-3][y+3]==l&&all[x-2][y+2]==l&&all[x-1][y+1]==l){
        e=1;
    }else if(all[x+1][y-1]==l&&all[x-3][y+3]==l&&all[x-2][y+2]==l&&all[x-1][y+1]==l){
        e=1;
    }else if(all[x-4][y+4]==l&&all[x-3][y+3]==l&&all[x-2][y+2]==l&&all[x-1][y+1]==l){
        e=1;
    }else if(all[x+1][y+1]==l&&all[x+2][y+2]==l&&all[x+3][y+3]==l&&all[x+4][y+4]==l){
        e=1;
    }else if(all[x+1][y+1]==l&&all[x+2][y+2]==l&&all[x+3][y+3]==l&&all[x-1][y-1]==l){
        e=1;
    }else if(all[x+1][y+1]==l&&all[x+2][y+2]==l&&all[x-2][y-2]==l&&all[x-1][y-1]==l){
        e=1;
    }else if(all[x+1][y+1]==l&&all[x-3][y-3]==l&&all[x-2][y-2]==l&&all[x-1][y-1]==l){
        e=1;
    }else if(all[x-4][y-4]==l&&all[x-3][y-3]==l&&all[x-2][y-2]==l&&all[x-1][y-1]==l){
        e=1;
    }
}
void f5(){
    cout<<"  ";
    for(int j=1;j<=col;j++){
            cout<<setw(3)<<j;
    }
    cout<<endl;
    for(int i=1;i<=row;i++){
            cout<<setw(2)<<i;
        for(int j=1;j<=col;j++){
            if(all[i][j]==0){
                cout<<setw(3)<<".";
            }else if(all[i][j]==1){
                cout<<setw(3)<<"黑";
            }else{
                cout<<setw(3)<<"白";
            }
              
        }
        cout<<endl;
    }
}
int main(int argc, char** argv) {
    for(int i=0;i<17;i++){
        for(int j=0;j<17;j++){
            all[i][j]=0;
        }
          
    }
    while(true){
        system("cls");
        f5();
        if(black){
            cout<<"黑棋请落子:";
            cin>>x>>y;
            if(x>16||y>16||all[x][y]!=0){
                continue;
            }
            all[x][y]=1;
            black=false;
            win();
            if(e==1){
                system("cls");
                f5();
                cout<<"黑方win";
                return 0;
            }
        }else{
            cout<<"白棋请落子:";
            cin>>x>>y;
            if(x>16||y>16||all[x][y]!=0){
                continue;
            }
            all[x][y]=2;
            win();
            if(e==1){
                system("cls");
                f5();
                cout<<"白方win";
                return 0;
            }
            black=true;
        }
    }
    return 0;
}

  

标签:判断,f5,16,int,win,五子棋,else,&&,输赢
From: https://www.cnblogs.com/fushuxuan/p/17810265.html

相关文章

  • 五子棋(未完成版)
    #include<bits/stdc++.h>usingnamespacestd;intlie=16,hang=16,lie_shu,hang_shu;intlist_flag[16][16];boolblack=true;intB;intblack_win(inta,intb){if(list_flag[a][b]==1&&list_flag[a][b+1]==1&&list_flag[a]......
  • 五子棋(能下棋 不能判断输赢)
    #include<iostream>#include<iomanip>usingnamespacestd;introw=16;intcol=16;boolblack=true;intall[17][17];voidF5(){for(intii=0;ii<=col;ii++){cout<<setw(3)<<ii;}cout<<endl;for(int......
  • 五子棋
    include<bits/stdc++.h>include<Windows.h>usingnamespacestd;intHENG=16,SHU=16;intIS_WIN=false;intALL[16][16];voidf5(){system("cls");cout<<"";for(inti=0;i<HENG;i++){cout<<setw(3)<<i+1;......
  • 五子棋2.0
    #include<iostream>#include<iomanip>usingnamespacestd;introw=16;intcol=16;boolblack=true;intall[17][17];voidF5(){for(intii=0;ii<=col;ii++){cout<<setw(3)<<ii;}cout<<endl;for(int......
  • 五子棋
    #include<iostream>#include<Windows.h>#include<iomanip>usingnamespacestd;intmian(){introw=16,col=16;for(inti=0;i<row;i++){cout<<setw(3)<<i+1;}for(intj=0;j<row;j++){cout......
  • 利用if判断分数级别
     代码如下:a=input('请输入分数:')score=int(a)ifscore>=90:print('A')elifscore>=80:print('B')elifscore>=70:print('C')elifscore>=60:print('D')else:print('E')......
  • 向量点乘判断点是否在线段上
    几种要考虑的情况1)点p和线段断点a,b重叠,pa•ab=pa.x*pa.y+ab.x*ab.y=02) pa,pb共线,则pa×pb=02-1)p在线段ab上,此时pa,pb的夹角为180度,cos(180)=-1,pa•ab=-|pa|*|ab|2-2)p在线段ab外,此时pa,pb的夹角为0度,cos(0)=1,pa•ab=|pa|*|ab|4)pa,pb不共线,cos(钝角)<0,cos(......
  • C# 判断时间是否在指定时间段内,判断班别时间
    protectedboolgetTimeSpan(stringtimeStr){//判断当前时间是否在工作时间段内string_strWorkingDayAM="07:00";string_strWorkingDayPM="19:00";TimeSpandspWorkingDayAM=DateTime.Parse(_strWorkingDayAM).TimeOfDay;TimeSpands......
  • java判断按键是否按下
    Java判断按键是否按下的实现1.简介在Java中,可以使用java.awt.event.KeyEvent类来判断按键是否按下。本文将为刚入行的小白介绍如何实现Java判断按键是否按下的方法。2.实现步骤以下是实现Java判断按键是否按下的步骤:步骤 描述步骤1 创建一个KeyListener对象步骤2 实现KeyList......
  • 816. 模糊坐标(来判断一个数是否是一个合法数字)
     对于一个整数来说其为一个合法数字前提是没有前导0对于一个小数可以分解一下其整数部分和小数部分,整数部分和上条一致,小数部分末尾不能为0 对于本题:我们可以先枚举逗号的位置,在对于左右两边枚举小数点的位置然后将两边拼起来就行。 deffindSplit(s:str)->List[st......