简介:
新增system()与Sleep()函数
人机对战改进版:
#include<bits/stdc++.h>//万能头
#include<windows.h>
#define ll long long
using namespace std;
ll n,a[1000][1000],x,y,b[1000][1000];
int xd[10]={1,-1,0};
int yd[10]={1,-1,0};
void init(){//初始化
for(int i=0;i<1000;i++) for(int j=0;j<1000;j++) a[i][j]=2;
}
bool find(){//判断黑子连珠
//竖着
ll sum=1,i,j;
i=x,j=y;
b[i][j]=3;
while(1){
if(a[i+1][j]==1){
i++;
sum++;
b[i][j]=3;
}
else break;
}
i=x,j=y;
while(1){
if(a[i-1][j]==1){
i--;
sum++;
b[i][j]=3;
}
else break;
}
if(sum>=5) return true;
//横着
sum=1;
i=x,j=y;
while(1){
if(a[i][j+1]==1){
j++;
sum++;
b[i][j]=3;
}
else break;
}
i=x,j=y;
while(1){
if(a[i][j-1]==1){
j--;
sum++;
b[i][j]=3;
}
else break;
}
if(sum>=5) return true;
//斜着 1
sum=1;
i=x,j=y;
while(1){
if(a[i-1][j-1]==1){
i--;
j--;
sum++;
b[i][j]=3;
}
else break;
}
i=x,j=y;
while(1){
if(a[i+1][j+1]==1){
i++;
j++;
sum++;
b[i][j]=3;
}
else break;
}
if(sum>=5) return true;
//斜着 2
sum=1;
i=x,j=y;
while(1){
if(a[i-1][j+1]==1){
i--;
j++;
sum++;
b[i][j]=3;
}
else break;
}
i=x,j=y;
while(1){
if(a[i+1][j-1]==1){
i++;
j--;
sum++;
b[i][j]=3;
}
else break;
}
if(sum>=5) return true;
return false;
}
bool find2(){//判断白子连珠
//竖着
ll sum=1,i,j;
i=x,j=y;
b[i][j]=3;
while(1){
if(a[i+1][j]==0){
i++;
sum++;
b[i][j]=3;
}
else break;
}
i=x,j=y;
while(1){
if(a[i-1][j]==0){
i--;
sum++;
b[i][j]=3;
}
else break;
}
if(sum>=5) return true;
//横着
sum=1;
i=x,j=y;
while(1){
if(a[i][j+1]==0){
j++;
sum++;
b[i][j]=3;
}
else break;
}
i=x,j=y;
while(1){
if(a[i][j-1]==0){
j--;
sum++;
b[i][j]=3;
}
else break;
}
if(sum>=5) return true;
//斜着 1
sum=1;
i=x,j=y;
while(1){
if(a[i-1][j-1]==0){
i--;
j--;
sum++;
b[i][j]=3;
}
else break;
}
i=x,j=y;
while(1){
if(a[i+1][j+1]==0){
i++;
j++;
sum++;
b[i][j]=3;
}
else break;
}
if(sum>=5) return true;
//斜着 2
sum=1;
i=x,j=y;
while(1){
if(a[i-1][j+1]==0){
i--;
j++;
sum++;
b[i][j]=3;
}
else break;
}
i=x,j=y;
while(1){
if(a[i+1][j-1]==0){
i++;
j--;
sum++;
b[i][j]=3;
}
else break;
}
if(sum>=5) return true;
return false;
}
bool find4(int t,int tt){//AI判断对方是否有连珠
//竖着
ll sum=1,i,j,ii,jj;
i=x,j=y;
while(1){
if(a[i+1][j]==tt){
i++;
sum++;
}
else break;
}
ii=x,jj=y;
while(1){
if(a[ii-1][jj]==2&&sum==t){
x=ii-1;
y=jj;
return true;
}
if(a[ii-1][jj]==tt){
ii--;
sum++;
}
else break;
}
if(sum==t){
if(a[i+1][j]==2&&sum==t){
x=i+1;
y=j;
return true;