[{"createTime":1735734952000,"id":1,"img":"hwy_ms_500_252.jpeg","link":"https://activity.huaweicloud.com/cps.html?fromacct=261f35b6-af54-4511-a2ca-910fa15905d1&utm_source=V1g3MDY4NTY=&utm_medium=cps&utm_campaign=201905","name":"华为云秒杀","status":9,"txt":"华为云38元秒杀","type":1,"updateTime":1735747411000,"userId":3},{"createTime":1736173885000,"id":2,"img":"txy_480_300.png","link":"https://cloud.tencent.com/act/cps/redirect?redirect=1077&cps_key=edb15096bfff75effaaa8c8bb66138bd&from=console","name":"腾讯云秒杀","status":9,"txt":"腾讯云限量秒杀","type":1,"updateTime":1736173885000,"userId":3},{"createTime":1736177492000,"id":3,"img":"aly_251_140.png","link":"https://www.aliyun.com/minisite/goods?userCode=pwp8kmv3","memo":"","name":"阿里云","status":9,"txt":"阿里云2折起","type":1,"updateTime":1736177492000,"userId":3},{"createTime":1735660800000,"id":4,"img":"vultr_560_300.png","link":"https://www.vultr.com/?ref=9603742-8H","name":"Vultr","status":9,"txt":"Vultr送$100","type":1,"updateTime":1735660800000,"userId":3},{"createTime":1735660800000,"id":5,"img":"jdy_663_320.jpg","link":"https://3.cn/2ay1-e5t","name":"京东云","status":9,"txt":"京东云特惠专区","type":1,"updateTime":1735660800000,"userId":3},{"createTime":1735660800000,"id":6,"img":"new_ads.png","link":"https://www.iodraw.com/ads","name":"发布广告","status":9,"txt":"发布广告","type":1,"updateTime":1735660800000,"userId":3},{"createTime":1735660800000,"id":7,"img":"yun_910_50.png","link":"https://activity.huaweicloud.com/discount_area_v5/index.html?fromacct=261f35b6-af54-4511-a2ca-910fa15905d1&utm_source=aXhpYW95YW5nOA===&utm_medium=cps&utm_campaign=201905","name":"底部","status":9,"txt":"高性能云服务器2折起","type":2,"updateTime":1735660800000,"userId":3}]
题目描述:
题解思路:
首先要明白两种状态:必胜态与必败态
必胜态:当前状态为必胜态,意思就是说,你有一种走法可以将当前局面的状态转向必败态(对手所面临的状态)
,因为题中说明,游戏双方会按照自己的最优策略来游戏,既然有一种方法可以使得对手所面临的的状态为必败态,那么一定会这样走。
必败态:当前游戏方所面临的状态为必败态,无论怎么走棋,只能将下一个状态转化为必胜态(对手一定会胜利)。
如果在深度搜索的过程中,可以找到必败态的话,那么当前状态为必胜态
如若不能的话,当前的状态只能是必败态
题解代码:
//灭鼠先锋游戏 //首先一定要明白什么是必胜态与必败态 #include <bits/stdc++.h> using namespace std;
map<string,bool> pp; //判断该字符串是否只有一个 bool isone0(string s) { int num=0; for(int
i=0;i<s.length();++i){ if(s[i]== 'O') num++; //只有一个棋子了,那么就是必败态 } if(num==1)
return true; //其他情况不做处理,因为判断不出来 // int tot = 0; // for(auto x:s) if(x=='O')
tot++; // return tot == 1; } bool dfs(string s) { //判断出结束条件,就是只有一个空格了,一定是必败态
if(isone0(s)) // pp[s] = false; return pp[s] = false; //if(isone0(s)) return
pp[s] = false; // 当棋盘只剩一个棋子 //判断这个状态是否已经存在 if(pp.count(s)==1) return pp[s];
//返回1表示可以找到 //开始走棋 //第一种情况,走1步棋子 for(int i=0;i<s.size();++i) { if(s[i]=='O'){
string temp2 = s; temp2[i] = 'X'; if(dfs(temp2) == false)
//如果可以到达必败态,那么一定是必胜态可以返回了 return pp[s] = true; } } //第二种情况,走两步棋子 for(int
i=0;i<s.size()-1;++i){ //等于三的情况跳过,是位于两个边界 if(s[i]=='O' && s[i+1]=='O'&& i!=3){
string tmp = s; tmp[i] = tmp[i+1] = 'X'; if(dfs(tmp) == false)
//如果可以到达必败态,那么一定是必胜态可以返回了 return pp[s] = true; } } return pp[s] = false;
//如果没能遇到必胜态,就是必败态 } int main(){ string
ss[4]={"XOOOOOOO","XXOOOOOO","OXOOOOOO","OXXOOOOO"}; //小蓝下完一步棋后的状态
//开始对每一种情况进行深搜 for(int i=0;i<4;++i){ string s = ss[i]; if(dfs(s) == false) {
cout<<"V"; //返回值是bool类型的,如果为真,此状态就是必胜态 } else { cout<<"L"; } } return 0; }
但是有一个问题就是:
为什么:if(isone0(s)) return pp[s] = false; // 当棋盘只剩一个棋子
不能替换为下面这种写法
if(isone0(s)) pp[s] = false; return pp[s] = false;