集训作业 洛谷P1032 字串变换
集训的题目有点多,先写困难的绿题吧(简单的应该想想就会了)
嗯,这个题看起来像个搜索呢(就是个搜索)
我们仔细想想就知道这个题肯定不能用深搜,可以优化的地方太少了,TLE是必然的。
那我们该怎么办呢?
很简单,用选代加深啊,我真是个睿(弱)智的小孩。
一遍自认为很强大的选代加深后:

嗯,放弃了。
明显以我的能力驾驭不了选代加深,优化不够……
我只能用优化力度更大的广搜了。
什么?为啥早不用?我说了,我是个睿(弱)智的小孩。
广搜可以用的优化更多了,有一个神奇的东西叫做记忆化,广搜有个特点,如果这个点之前曾经查询到过,那这次用的步数就一定比上次少。我们定义一个数组表示来过没有,曾经来过就可以停下了。如果你不知道“这次用的步数就一定比上次少”是为什么的话就戳这里。
好了,该用什么搜索已经定了,该解决一下第二恶心的东西了。
字符串,一个新手的噩梦(我看见了都恶心)
但这个题竟然让我们匹配字符串(对于我这种渣渣简直毫无人性),没办法,只能硬上了。
我们来愉快的模拟吧。具体代码后面一起贴出来吧。
代码出现了:
#include<iostream>
#include<cstdio>
#include<cstring>
#include<queue>
#include<map>
using namespace std;
string n,m,gb;
long long w,t,shu,bj,bss;
string as,jc;
queue<string>s;
queue<int>bs;
map<string,int>mp;
struct hehe
{
string a,b;
long long cd;
}sz[10];
bool pd(int x,int y,string mb,string yl)//这就是我们的判断环节,x和y是开始和结束节点,y是故意大了一个的。
{
//mb是目标,就是看看原来的字符串x到y-1位是不是和条件对应(理解成脏话的同学要考虑一下自己的品德哦),yl当然就是原来的意思啦。
jc="";
for(int i=x;i<y;i++)
{
jc+=yl[i];//把要对比的一段取出来
}
if(jc==mb)//是一样的,可以替换。
{
return true;
}
}
void pj(int x,int y,string mb,string yl)//刚才替换成功了,现在要来看看替换完之后的字符串是什么。
{
jc="";//又是jc,我也忘了为啥叫jc了,可能因为他不重要
for(int i=0;i<x;i++)
{
jc+=yl[i];//替换的前面
}
jc+=mb;//替换的部分
for(int i=y;i<yl.length();i++)
{
jc+=yl[i];//替换的后面
}
//成品jc出炉
return;
}
void bfs()//喜闻乐见的广搜环节
{
while(s.empty()!=true)//还有路,不要放弃
{
as=s.front();//来看看这次在哪里
bss=bs.front();//走到这里用了多少步
if(as==m)//哎呀到地方了。
{
bj=1;
cout<<bss<<endl;//嗯,我一共走了bss步。
return;
}
for(int i=0;i<shu;i++)//额,又没走到,看看下一步有什么情况可以走。
{
for(int j=0;j+sz[i].cd-1<as.length();j++)//如果接下来的数量不够我换,那就不走了。
{
if(pd(j,j+sz[i].cd,sz[i].a,as)==true&&bss!=10)//我是可以换的,而且移动次数也没到10步。换吧
{
pj(j,j+sz[i].cd,sz[i].b,as);//来获取一下我该变成什么样子的
if(mp[jc]==0)//他没出现过哎,这是第一次来,存进去
{
mp[jc]=1;//现在他出现了
s.push(jc);
bs.push(bss+1);//走到变成现在前一步用了bss步,再走一步,自然就是bss+1啦。
}
}
}
}
s.pop();//别忘了删除掉哦,这可是一次性用品
bs.pop();
}
}
int main()
{
cin>>n>>m;
mp[n]=1;//这个是map,也就是记忆化数组。
s.push(n);//储存所有下一步可移动地点的队列s
bs.push(0);//储存对应操作步数的队列bs
while(cin>>sz[shu].a>>sz[shu].b)//一个神奇的方法,输入Ctrl+Z就可以停止了(这是一个大佬教我的,他叫FUXyao)
{
sz[shu].cd=sz[shu].a.length();//一会准备匹配用的长度
shu++;
}
bfs();
if(bj==0)//不可能到达目标。
{
cout<<"NO ANSWER!"<<endl;
}
return 0;
}
代码一如既往的臭长,希望同学们谅解。
如果有不明白的地方,可以评论在下面,我会更改的。
集训作业 洛谷P1032 字串变换的更多相关文章
- [洛谷P1032] 字串变换
洛谷题目链接:字串变换 题目描述 已知有两个字串 A, B 及一组字串变换的规则(至多6个规则): A1 -> B1 A2 -> B2 规则的含义为:在 A$中的子串 A1 可以变换为 B ...
- 洛谷 P1032 字串变换题解
题目链接:https://www.luogu.org/problem/P1032 题目描述 已知有两个字串A,BA,B及一组字串变换的规则(至多66个规则): A_1A1 ->B_1B1 A ...
- 洛谷 P1032 字串变换
题目描述 已知有两个字串 A, B 及一组字串变换的规则(至多6个规则): A1 -> B1 A2 -> B2 规则的含义为:在 A$中的子串 A1 可以变换为 B1.A2 可以变换为 B ...
- 洛谷 P1032 字串变换 (BFS)
题目传送门 我即使是死了,钉在棺材里了,也要在墓里,用这腐朽的声带喊出 STL大法好 这题最麻烦的其实是处理字符串,真正的搜索部分我个人认为也就只有橙题或黄题的难度.而处理字符串,正如前面所说,STL ...
- 洛谷 P1032 字串变换 题解
每日一题 day19 打卡 Analysis 广搜+map判重 用find寻找字串,再用replace替换字串 这里的map相当于正常广搜的一个book的作用 #include<iostream ...
- 洛谷P1032 字串变换【bfs】
题目链接:https://www.luogu.org/problemnew/show/P1032 题意: 给定一个原字符串和目标字符串,以及几个字符串变换的规则. 问能否根据这几个规则在十步之内把原字 ...
- 洛谷P1032 字串变换-题解
https://www.luogu.org/problemnew/show/P1032--(题目传送) 好在数据范围很小,暴力一点也能过.思路较简单,按照所有规则,从第一位开始广搜. 注意:1.str ...
- 洛谷 P1032 字串变换(map)
题目传送门 解题思路: 搜索题,因为要求最少次数,用bfs. AC代码: #include<cstdio> #include<iostream> #include<cst ...
- P1032 字串变换 字符串BFS
题目描述 已知有两个字串A,BA,B及一组字串变换的规则(至多66个规则): A_1A1 ->B_1B1 A_2A2 -> B_2B2 规则的含义为:在 AA中的子串 A_1A1 ...
随机推荐
- 写给大忙人的Redis主从复制,花费五分钟让你面试不尴尬
相信很多小伙伴都已经配置过主从复制,但是对于redis主从复制的工作流程和常见问题很多都没有深入的了解.咔咔这次用时俩天时间给大家整理一份redis主从复制的全部知识点. 本文实现所需环境 cento ...
- Rigidbody(刚体)方法的初步学习(一)
概要:这次将简单的了解Rigidbody中的各种方法属性,以官方的API为顺序研究. 蛮牛API翻译:Rigidbody组件控制物体的位置—它使物体在重力影响下下落,并可计算物体将怎样响应碰撞.当操作 ...
- selenium(9)- Xpath的详细使用
什么是Xpath 官方:XPath 是一门在 XML 文档中查找信息的语言.XPath 用于在 XML 文档中通过元素和属性进行导航 [XPath 使用路径表达式来选取 XML 文档中的节点或者节点集 ...
- 解决Mac中anaconda作图中文异常显示的问题
说明 本篇主要针对在MAC系统中Anaconda环境下,matplotlib显示不了中文的问题,提出解决Python绘图时中文显示的方法. 运行环境 macOS Mojave 10.14.6 Pyth ...
- matplotlib 强化学习
matplotlib 强化学习 import matplotlib.pyplot as plt ...
47. 尚硅谷_佟刚_SpringMVC_文件上传.avi 参看博客https://www.cnblogs.com/hanfeihanfei/p/7931758.html相当的经典 我是陌生人关于Sp ...
- docx.opc.exceptions.PackageNotFoundError: Package not found at '文件名.docx' 问题解决
编译源程序时,提示:docx.opc.exceptions.PackageNotFoundError: Package not found at '文件名.docx' . 源文件明明存在啊,难道是用的 ...
- 记一次WIN10 WLAN消失修复
事故现场:在win10自动更新后 在网路和Internet中WLAN消失 无法发现wifi了 设备管理器中wireless驱动上有黄色感叹号 解决办法: 右键有感叹号的wireless驱动,选择属性, ...
- Hive 报错SemanticException Error in parsing
以下sql执行时报错SemanticException Error in parsing select clr.id,clr.customer_id,clr,contract_code,clr.cor ...
- 新技术新框架不断涌现,目前学习web前端开发都要掌握什么?
web前端开发由网页制作演变而来,随着web2.0的发展,网页不再只是承载单一的文字和图片,各种丰富媒体让网页的内容更加生动,网页上软件化的交互形式为用户提供了更好的使用体验,这些都是基于前端技术实现 ...