问题描述:
?井字棋,英文名叫Tic-Tac-Toe,是一种在3*3格子上进行的连珠游戏,和五子棋比较类似,由于棋盘一般不画边框,格线排成井字故得名。只要横,竖,斜三点一线即可胜利。CXK经过一系列唱、跳、rap、打篮球后觉得很累,想和AW玩这个游戏,CXK用O(大写字母O)AW用X(大写字母X)。如果CXK赢了那么输出CXKNB,如果AW赢了那么输出AWNB。? 游戏保证必有一个人获胜。??
样例输入:
OXO
XXO
OXX
样例输出:
AWNB
原因分析:
直接判断?横,竖,斜三点一线,有点困难,可以将字母转化成数字 1? 0(true即1) 用一个二维int数组来记录O的位置? 若temp=3 则CXKNB? ?若temp=0? 则AWNB? 同时每次判断后都要return 0; 结束程序
解决方案:
#include<bits/stdc++.h>
using namespace std;
int main()
{
char str[4];
int i,j,n,a[3][3],p=0,f=0;
for(i=0;i<3;i++)
{
cin>>str;
for(j=0;j<3;j++)
a[i][j]=(str[j]=='O');
}
for(i=0;i<3;i++)
{
int temp=0;
for(j=0;j<3;j++)
temp+=a[i][j];
if(temp==3)
{
cout<<"CXKNB"<<endl;
return 0;
}
else if(temp==0)
{
cout<<"AWNB"<<endl;
return 0;
}
}
for(j=0;j<3;j++)
{
int temp=0;
for(i=0;i<3;i++)
temp+=a[i][j];
if(temp==3)
{
cout<<"CXKNB"<<endl;
return 0;
}
else if(temp==0)
{
cout<<"AWNB"<<endl;
return 0;
}
}
{
int temp=a[0][0]+a[1][1]+a[2][2];
if(temp==3)
{
cout<<"CXKNB"<<endl;
return 0;
}
else if(temp==0)
{
cout<<"AWNB"<<endl;
return 0;
}
}
{
int temp=a[0][2]+a[1][1]+a[2][0];
if(temp==3)
{
cout<<"CXKNB"<<endl;
return 0;
}
else if(temp==0)
{
cout<<"AWNB"<<endl;
return 0;
}
}
return 0;
}
|