HDU1846(博弈论,Brave Game)

题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1846

巴什博奕,可以用对抗搜索,也可以用数学方法来解决。

所谓对抗搜索,其实是一种记忆化搜索,下面给出对抗搜索的模板:

bool dfs(当前状态)  //判断当前状态是否是必胜状态
{
	if (当前状态已经搜索过) 
		return 搜索结果;
	if (当前状态已经是末状态或者已经可以判断出胜负)
	{
		标记该状态已经搜索过;
		标记该状态是否是必胜状态;
		return 是否是必胜状态;
	}
	
	标记该状态已经搜索过;
	标暂时记该状态不是必胜状态;
	for (每一种合法的规则)
		if (!dfs(后继状态))
	{
		标记该状态是必胜状态;
		break;
	}
	
	return 是否是必胜状态;
}

下面给出这道题的对抗搜索的代码:

#include<iostream>
using namespace std;

bool f[1010][1010];  //false为P点,true为N点
bool g[1010][1010];  //是否已经搜索过
int n, m;

bool dfs(int x)  //判断x是N点(true)还是P点(false)
{
    if (g[x][m])   //当前状态已经搜索过
        return f[x][m];  //搜索结果
    if (x <= m)  //当前状态已经是末状态或者已经可以判断出胜负
    {
        f[x][m] = true;  //标记该状态是必胜状态
        return f[x][m];  //返回结果
    }

    f[x][m] = false; g[x][m] = true;  //标暂时记该状态不是必胜状态;标记该状态已经搜索过;
    for (int i=1; i<=min(m,x); i++)   //每一种合法的规则
        if (!dfs(x-i))  //判断后继状态
    {
        f[x][m] = true;  //标记该状态是必胜状态
        break;
    }

    return f[x][m];  //返回结果
}

void print(bool flag)
{
    if (flag)
        cout<<"first"<<endl;
    else
        cout<<"second"<<endl;
}

int main()
{
    int C;

    cin>>C;
    while (C > 0)
    {
        C--;

        cin>>n>>m;
        print(dfs(n));
    }

    return 0;
}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值