填字母游戏【蓝桥杯】/博弈+dfs

填字母游戏



博弈+dfs

cpp 复制代码
#include<iostream>
#include<map>
using namespace std;
//要用map存储已经处理过的字符串不然会超时
map<string,int> m;
//dfs返回的就是结果
int dfs(string s)
{
    //剪枝
    if(m.find(s)!=m.end()) return m[s];
    //找到LOL代表输了
    if(s.find("LOL")!=string::npos) return m[s]=-1;
    //找不到空位表示平局
    if(s.find("*")==string::npos) return m[s]=0;
    int ping=0;
    for(int i=0;i<s.size();i++)
    {
        if(s[i]=='*')
        {
            s[i]='L';
            if(dfs(s)==-1) 
            {
                //要回溯后才能存到m中
                s[i]='*';
                return m[s]=1;
            }
            if(dfs(s)==0) ping=1;
            s[i]='O';
            if(dfs(s)==-1) 
            {
                s[i]='*';
                return m[s]=1;
            }
            if(dfs(s)==0) ping=1;
            s[i]='*';
        }
    }
    //ping不为0表示有可能平局,返回0
    if(ping) return m[s]=0;
    //否则返回-1
    return m[s]=-1;
}
int main()
{
    int n;
    cin>>n;
    for(int i=0;i<n;i++)
    {
        string s;
        cin>>s;
        cout<<dfs(s)<<endl;
    }
    return 0;
}
相关推荐
悦悦欧呐呐呐呐27 分钟前
休闲摸鱼小游戏扫雷游戏|下载即玩
游戏
wanhengidc10 小时前
云手机是由什么组成的?
运维·服务器·web安全·游戏·智能手机
世洋Blog15 小时前
利用<<左移运算符优雅的设计游戏能力的任意组合和判断
游戏·unity·c#
da_vinci_x17 小时前
PS 3D Viewer (Beta):概念美术的降维打击,白模直接在PS里转光打影出5张大片
人工智能·游戏·3d·prompt·aigc·材质·游戏美术
め.18 小时前
用Unity复刻童年经典游戏—愤怒的小鸟
游戏
喵了几个咪18 小时前
游戏字体渲染
开发语言·python·游戏
张丶大帅19 小时前
别踩白块游戏(附源代码)
c语言·游戏
2501_9400940219 小时前
模拟器全部BIOS合集 RetroArch BIOS 解决模拟器提示缺少bios的问题 通用所有游戏模拟器
游戏
wanhengidc20 小时前
跨境电商为什么依赖于云手机
运维·服务器·游戏·智能手机·云计算
2501_915106321 天前
游戏上架 App Store 的技术流程解析 从构建到审核的全流程指南
游戏·macos·ios·小程序·uni-app·cocoa·iphone