Codeforces Round #390 (Div. 2)B Ilya and tic-tac-toe game

题目大意:

      两个人走三子棋问下一步是否能赢。

题目解法:

      枚举所有情况就行了,反正在边上的就8种,在中间的4种。

代码:

#include "iostream"
#include "algorithm"
#include "cstdio"
#include "math.h"
#include "string"
#include "string.h"
using namespace std;
int go[2][4] = { {-1,0,1,0},{0,1,0,-1} };
char mp[10][10];
bool judge(int x, int y) {
	if (mp[x - 1][y] == 'x'&&mp[x - 2][y] == 'x') {
		return true;
	}
	if (mp[x + 1][y] == 'x'&&mp[x + 2][y] == 'x') {
		return true;
	}
	if (mp[x][y - 1] == 'x'&&mp[x][y - 2] == 'x') {
		return true;
	}
	if (mp[x][y + 1] == 'x'&&mp[x][y + 2] == 'x') {
		return true;
	}
	if (mp[x + 1][y + 1] == 'x'&&mp[x + 2][y + 2] == 'x') {
		return true;
	}
	if (mp[x - 1][y - 1] == 'x'&&mp[x - 2][y - 2] == 'x') {
		return true;
	}
	if (mp[x + 1][y - 1] == 'x'&&mp[x + 2][y - 2] == 'x') {
		return true;
	}
	if (mp[x - 1][y + 1] == 'x'&&mp[x - 2][y + 2] == 'x') {
		return true;
	}
	return false;
}
bool judge2(int x, int y) {
	if (mp[x - 1][y] == 'x'&&mp[x + 1][y] == 'x') {
		return true;
	}
	if (mp[x][y - 1] == 'x'&&mp[x][y + 1] == 'x') {
		return true;
	}
	if (mp[x + 1][y + 1] == 'x'&&mp[x - 1][y - 1] == 'x') {
		return true;
	}
	if (mp[x + 1][y - 1] == 'x'&&mp[x - 1][y + 1] == 'x') {
		return true;
	}
	return false;
}
int main()
{
	for (int i = 2;i <= 5;i++) {
		for (int j = 2;j <= 5;j++) {
			scanf(" %c", &mp[i][j]);
		}
	}
	bool flag = false;
	for (int i = 2;i <= 5;i++) {
		for (int j = 2;j <= 5;j++) {
			if (mp[i][j] == 'x') {
				if (judge(i, j)) {
					flag = true;
					break;
				}
			}
		}
		if (flag)
			break;
	}
	if (!flag) {
		for (int i = 2;i <= 5;i++) {
			for (int j = 2;j <= 5;j++) {
				if (mp[i][j] == '.') {
					if (judge2(i, j)||judge(i,j)) {
						flag = true;
						break;
					}
				}
			}
			if (flag)
				break;
		}
	}
	if (flag)
		puts("YES");
	else
		puts("NO");
    return 0;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值