问题描述:
井字棋,英文名叫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;
}