题目传送门

我即使是死了,钉在棺材里了,也要在墓里,用这腐朽的声带喊出

STL大法好

这题最麻烦的其实是处理字符串,真正的搜索部分我个人认为也就只有橙题或黄题的难度。而处理字符串,正如前面所说,STL大法好!虽然也有好多人用了STL,但我个人认为我的更精巧一些(各位dalao不要打我 ~(>_<。)\ )

用STL实现替换是这样的:

  1. string repl(int be,string x,string y,string z) //将字符串x从be位置开始的第一个子串y替换成z,如果子串y不被x包含,则返回x
  2. {
  3. int pos=x.find(y,be); //寻找子串y在x中的位置,如果不存在,返回-1
  4. if(pos>=0) //如果y存在,则进行替换操作
  5. x=x.replace(pos,y.size(),z); //将x在pos位置的长度为y.size的串(也就是y)替换成z
  6. return x; //返回更改后的字符串
  7. }

用STL实现的判重是这样的:

  1. map <string,bool> vis;

这样再进行广搜寻找最优解就方便得多了。由于广搜实现起来很简单,就不单独解释了,直接上完整代码。

  1. #include<iostream>
  2. #include<cstdio>
  3. #include<map>
  4. using namespace std;
  5. struct yyy{
  6. string f,
  7. t;
  8. }rule[10]; //存变换规则
  9. struct hhh{
  10. string now;
  11. int st;
  12. }q[10001]; //模拟队列,now是当前的字串,st是步数
  13. int h=1,t;
  14. map<string,bool> vis; //map查重
  15. string repl(int be,string x,string y,string z) //替换子串,前面已经讲过了
  16. {
  17. int pos=x.find(y,be);
  18. if(pos>=0)
  19. x=x.replace(pos,y.size(),z);
  20. return x;
  21. }
  22. int main()
  23. {
  24. //输入
  25. string a,b; int n=0;
  26. cin>>a>>b;
  27. while(cin>>rule[++n].f&&cin>>rule[n].t)
  28. //搜索
  29. q[++t].now=a;
  30. vis[a]=1;
  31. while(h<=t)
  32. {
  33. for(int i=1;i<=n;i++)
  34. {
  35. for(int j=0;j<q[h].now.size();j++)
  36. {
  37. string x=repl(j,q[h].now,rule[i].f,rule[i].t);
  38. if(x==b)
  39. {
  40. cout<<q[h].st+1;
  41. return 0;
  42. }
  43. if(!vis[x]&&q[h].st+1<=10)
  44. {
  45. vis[x]=1;
  46. q[++t].now=x; q[t].st=q[h].st+1;
  47. }
  48. }
  49. }
  50. h++;
  51. }
  52. cout<<"NO ANSWER!";
  53. return 0;
  54. }

洛谷 P1032 字串变换 (BFS)的更多相关文章

  1. [洛谷P1032] 字串变换

    洛谷题目链接:字串变换 题目描述 已知有两个字串 A, B 及一组字串变换的规则(至多6个规则): A1 -> B1 A2 -> B2 规则的含义为:在 A$中的子串 A1 可以变换为 B ...

  2. 洛谷 P1032 字串变换题解

    题目链接:https://www.luogu.org/problem/P1032 题目描述 已知有两个字串A,BA,B及一组字串变换的规则(至多66个规则): A_1A1​ ->B_1B1​ A ...

  3. 洛谷 P1032 字串变换

    题目描述 已知有两个字串 A, B 及一组字串变换的规则(至多6个规则): A1 -> B1 A2 -> B2 规则的含义为:在 A$中的子串 A1 可以变换为 B1.A2 可以变换为 B ...

  4. 洛谷 P1032 字串变换 题解

    每日一题 day19 打卡 Analysis 广搜+map判重 用find寻找字串,再用replace替换字串 这里的map相当于正常广搜的一个book的作用 #include<iostream ...

  5. 洛谷P1032 字串变换【bfs】

    题目链接:https://www.luogu.org/problemnew/show/P1032 题意: 给定一个原字符串和目标字符串,以及几个字符串变换的规则. 问能否根据这几个规则在十步之内把原字 ...

  6. 洛谷 P1032 字串变换(map)

    题目传送门 解题思路: 搜索题,因为要求最少次数,用bfs. AC代码: #include<cstdio> #include<iostream> #include<cst ...

  7. 集训作业 洛谷P1032 字串变换

    集训的题目有点多,先写困难的绿题吧(简单的应该想想就会了) 嗯,这个题看起来像个搜索呢(就是个搜索) 我们仔细想想就知道这个题肯定不能用深搜,可以优化的地方太少了,TLE是必然的. 那我们该怎么办呢? ...

  8. 洛谷P1032 字串变换-题解

    https://www.luogu.org/problemnew/show/P1032--(题目传送) 好在数据范围很小,暴力一点也能过.思路较简单,按照所有规则,从第一位开始广搜. 注意:1.str ...

  9. luogu题解P1032字串变换--BFS+STL:string骚操作

    题目链接 https://www.luogu.org/problemnew/show/P1032 分析 这题本来很裸的一个BFS,发现其中的字符串操作好烦啊.然后就翻大佬题解发现用STL中的strin ...

随机推荐

  1. 51nod1414【思维】

    思路: 直接可以枚举1-n,如果枚举到是n的约数i,那么暴力枚举起点,其余点用i累加就一定是正多边形.复杂度是(n*n的公约数个数(最多80)): const int N=2e4+10; int a[ ...

  2. 51nod1639(组合数学)

    题目链接:http://www.51nod.com/onlineJudge/questionCode.html#!problemId=1639 题意:中文题诶- 思路:组合数学 n根鞋带要组成一个环, ...

  3. 多次页面跳转后pop回主界面的问题

    最近写代码的时候出了点BUG, 查阅资料后终于解决了. 问题原因大概是: 项目中所有的viewController都是继承自一个封装好的viewController. navigationbar, n ...

  4. vmware vSAN 入门

    参考:https://docs.vmware.com/cn/VMware-vSphere/6.5/com.vmware.vsphere.virtualsan.doc/GUID-18F531E9-FF0 ...

  5. 集合框架Collection<E>接口

  6. lucene原理及java实现

    https://blog.csdn.net/liuhaiabc/article/details/52346493 https://blog.csdn.net/yang307511977/article ...

  7. DRF教程2-请求和响应

    Request objects REST framework中有一个Request对象,是HttpRequest的扩展,提供了新的请求解析,Request的核心功能就是request.data,它和r ...

  8. 【loj10064】黑暗城堡

    #10064. 「一本通 3.1 例 1」黑暗城堡 内存限制:512 MiB 时间限制:1000 ms 标准输入输出 题目类型:传统    评测方式:文本比较 上传者: 1bentong 提交     ...

  9. Codeforces Round #547 (Div. 3) D. Colored Boots

    链接:https://codeforces.com/contest/1141/problem/D 题意: 给连个n长度的字符串. 求两个字符串相同字符对应位置的对数,并挨个打印. 字符:?可以代替任何 ...

  10. Codeforces Round #547 (Div. 3) A.Game 23

    链接:https://codeforces.com/contest/1141/problem/A 题意: 给n和m,有两种操作:将n×2 或 n×3,求最少的乘法次数由n得到m. 不能得到时为-1. ...