首页 > 其他分享 >五子棋 人机(不完整)

五子棋 人机(不完整)

时间:2023-11-05 10:12:46浏览次数:27  
标签:人机 16 int win 五子棋 else 完整 && f5

#include <iostream>
#include <iomanip>
#include <ctime>
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{
        	srand(time(0));
        	x=rand()%16;
            y=rand()%16;
            while(all[x][y]!=0){
            	x=rand()%16;
            	y=rand()%16;
			}
            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;
}

  

标签:人机,16,int,win,五子棋,else,完整,&&,f5
From: https://www.cnblogs.com/As10016/p/17810259.html

相关文章

  • 五子棋(可判断输赢)
    #include<iostream>#include<iomanip>usingnamespacestd;introw=16;intcol=16;intall[17][17];boolblack=true;boolwhilt;intx,y;inta=1;intt=0;inte=0;boolwin(){intl=all[x][y];if(all[x][y-1]==l&&all[x][y-2]==......
  • 五子棋(未完成版)
    #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......
  • 第五章知识点完整性总结
    第五章定时器及时钟服务本章讨论了定时器和定时器服务;介绍了硬件定时器的原理和基于Intelx86的PC中的硬件定时器;讲解了CPU操作和中断处理;描述了Linux中与定时器相关的系统调用、库函数和定时器服务命令;探讨了进程间隔定时器、定时器生成的信号硬件定时器定时器是由......
  • 如何发包到中央仓库-完整教程
    相信很多小伙伴自己都会有一些包,我们可以将包发布中央仓库,然后直接通过maven来使用这些包,下面就整理下如何将包发到中央仓库。新建项目第一步,我们需要在sonatype上注册一个账号,这一步就不再演示了。注册好账户之后,然后我们来创建项目。点击新建按钮,问题类型选择NewProject,如......
  • 唯一一套自带saas云平台服务完整功能的开源制造业erp系统erp5
    唯一一套自带saas云平台服务完整功能的开源制造业erp系统erp5erp5是唯一一套自带saas云平台服务完整功能的开源制造业erp系统,提供了saas租户注册,erp开通,日常监控,备份恢复,计费等功能,支持微信注册和微信支付......
  • Linux常用命令汇总:太完整了,值得收藏!
    你们好,我的网工朋友。前段时间发了个交换路由相关的命令合集,不少做运维的朋友说,怎么没有运维人常用的Linux命令汇总?这不就安排上了嘛!搞运维,命令绝对是最基本的了,今天发的这些常用命令都掌握了,肯定能提升你的工作效率,都存起来啊。今日文章阅读福利:《运维必读书籍:Linux就该这样学(电......