啊本来以为2002的题应该会比较友善于是很naive地像模拟一样用着stl乱玩结果死也过不了最后一个点qaq

心情很悲痛于是为了解放自我

 #include<iostream>
 #include<cstdio>
 #include<cstdlib>
 #include<cstring>
 #include<algorithm>
 #include<string>
 #include<map>
 using namespace std;
 ],bb[];
 ];
 ];
 map <string,bool> k;
 int main(){
 //    freopen ("string.in","r",stdin);
 //    freopen ("string.out","w",stdout);
     cin>>a>>b;
     ;
     while (cin>>aa[j]>>bb[j]) j++;
     j--;
     ,t=;
     q[]=a;
     k[a]=;
     ;
     while (h<t){
         string u=q[++h];
         string l;
         int d=tt[h];
         if (u==b) {fl=tt[h];break;}
         ) {fl=;break;}
         ;
         ;i<=j;++i){
             int sr=aa[i].length();
             );
             ) continue;
             ;++o){
                 if (u.substr(o,sr)!=aa[i]) continue;
                 l=u;
                 l.replace(o,sr,bb[i]);
                 ;;}
                 ,k[l]=;
                 ) {cout<<;}//先让我强行卡过最后一个点爽一下
             }
          }
      }
     ) cout<<"NO ANSWER!";
     else cout<<fl;
     ;
   }

后来想了一下这样还是不太好

去网上看了一下双向广搜 大概就是一种在知道初始并且也知道目标状态的情况下的优化型搜索

一般有两种方法 一种是直接交替着搜 但是这种似乎有点问题 好像是说如果要交替应该是一层一层地交替

另外一种是相对而言更优秀一点的 就是每次选两边中状态更少的那一队进行扩展 这样能使扩展的节点更少一点吧

具体实现大概就是把原来的bfs分为两端 然后好像还可以用^操作

我实在是太懒了所以没怎么想好好打就把上面那个乱玩的随便复制了一遍 勉勉强强最后一点还是拖过了(本来就只想着要过最后一个点23333

一定是stl太慢了才不是我垃圾呢哼(睁眼说瞎话

 #include<iostream>
 #include<cstdio>
 #include<cstdlib>
 #include<cstring>
 #include<algorithm>
 #include<string>
 #include<map>
 using namespace std;
 ],bb[];
 ],p[];
 ][];
 map <];
 map <string,int> kk;
 int main(){
     freopen ("string.in","r",stdin);
     freopen ("string.out","w",stdout);
     cin>>a>>b;
     ;
     while (cin>>aa[j]>>bb[j]) j++;
     j--;
     ,t=,hh=,ttt=;
     q[]=a;
     p[]=b;
     k[][a]=;
     k[][b]=;
     ;
     while (h<t&&hh<ttt){
         if (t<=ttt){
             string u=q[++h];
             string l;
             ][h];
             ) {fl=;break;}
             ;
             ;i<=j;++i){
                 int sr=aa[i].length();
                 );
                 ) continue;
                 ;++o){
                     if (u.substr(o,sr)!=aa[i]) continue;
                     l=u;
                     l.replace(o,sr,bb[i]);
                     ][l]) {cout<<d++tt[][kk[l]];;
                     }
                     ][l]) q[++t]=l,tt[][t]=d+,k[][l]=,kk[l]=t;
             }
          }
         }
         else{
             string u=p[++hh];
             string l;
             ][hh];
             ) {fl=;break;}
             ;
             ;i<=j;++i){
                 int sr=bb[i].length();
                 );
                 ) continue;
                 ;++o){
                     if (u.substr(o,sr)!=bb[i]) continue;
                     l=u;
                     l.replace(o,sr,aa[i]);
                     ][l]) {cout<<d++tt[][kk[l]];;}
                     ][l]) p[++ttt]=l,tt[][ttt]=d+,k[][l]=,kk[l]=ttt;
                 }
             }
         }
     }
     ) cout<<"NO ANSWER!";
     else cout<<fl;
     ;
   }

NOIP2002 字符变换的更多相关文章

  1. 洛谷 P1032 字符变换

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

  2. LuoguP1032 字符变换(BFS)

    题目链接为:https://www.luogu.org/problemnew/show/P1032 思路:看到数据比较小,而且最多有6个规则,就可以用搜索去做了,我用的BFS,大体思路如下: 定义结构 ...

  3. python中实现打印特定字符变换

    首先需要将 lib文件 放在该文件同一目录 使用的时候,先导入 from lib.common import print_msg ,然后调用里面的 print_msg() 方法即可! lib文件地址: ...

  4. $NOIp$提高组历年题目复习

    写在前面 一个简略的\(NOIp\)题高组历年题目复习记录.大部分都有单独写题解,但懒得放\(link\)了\(QwQ\).对于想的时候兜了圈子的题打上\(*\). \(NOIp2018\ [4/6] ...

  5. $NOIp$提高组做题记录

    对了我在这里必须讲一个非常重要的事情,就是前天也就是$2019.8.21$的傍晚,我决定重新做人了$!!$ 其实之前没怎么做$Noip$题,那就从现在开始叭

  6. hdu----(4545)魔法串(LCS)

    魔法串 Time Limit: 3000/1000 MS (Java/Others)    Memory Limit: 65535/32768 K (Java/Others)Total Submiss ...

  7. fw:sed的高级用法

    转的,找不到原创了.... sed高级用法 <收藏> 首先,应该明白模式空间的定义.模式空间就是读入行所在的缓存,sed对文本行进行的处理都是在这个缓存中进行的.这对接下来 的学习是有帮助 ...

  8. Toad

    1. Toad 规矩: toad 不会违反, 限制, 扩大 你当前用户的权限, toad 不会影响你定义的关于instance的内容. 2. toad 可以执行大部分在 sql*plus 中执行的命令 ...

  9. 进程间通信之popen和pclose函数

    常见的操作是创建一个管道连接到另一个进程,然后读其输出或向其输入端发送数据,为此,标准I/O库提供了两个函数popen和pclose.这两个函数实现的操作是:创建一个管道,调用fork产生一个子进程, ...

随机推荐

  1. laravel 500错误的一个解决办法

    我从svn上update下来了开发环境的目录,结果当我访问本地的根目录的时候却报了500错误,百度了许多,也看了很多博客,发现都没有解决我的问题,所以我觉得我的解决办法值得一写,当你从svn上upda ...

  2. 在Linux中使用线程

    我并不假定你会使用Linux的线程,所以在这里就简单的介绍一下.如果你之前有过多线程方面的编程经验,完全可以忽略本文的内容,因为它非常的初级. 首先说明一下,在Linux编写多线程程序需要包含头文件p ...

  3. MongoDB-Use --auth parameter with connecting error

    When you use mongoDB started as "mongod --dbpath ../../data/db --auth", and you use the ex ...

  4. mac下出现xcrun: error导致git、svn无法使用的解决办法

    现象:xcrun: error: invalid active developer path (/Library/Developer/CommandLineTools), missing xcrun ...

  5. Golang学习--包管理工具glide

    上一篇文章中我们已经成功的运行了go的代码,这是我们迈出的最基础的一步. 一个项目通常会依赖很多外部的库,当依赖的库比较多的时候,手工管理就会比较麻烦,这个时候就需要包管理工具出场了,帮你管理好所有依 ...

  6. 利用模板template动态渲染jsp页面

    一.场景 在js中写html简直是噩梦,刚进新公司,在codereview的时候得知可以通过将html模板写在jsp页面,然后由js调取模板,利用replace()方法替换传值的方式避免在js中拼接h ...

  7. JAVA中静态修饰符static的学习(初学)

    静态修饰符static,用于修饰类中的成员变量和成员函数. 用static修饰的成员变量也可叫做类变量. 什么时候使用静态 什么时候定义静态成员变量?     当对象中出现共享数据时,将该数据定义为静 ...

  8. MATLAB中最基本函数plot()的用法

    1二维平面图形 1.1基本图形函数 画出一条正弦曲线和一条余弦曲线 1.1.1绘图参数表 y 黄- 实线. 点< 小于号 m 紫: 点线o 圆s 正方形 c 青-. 点划线x 叉号d 菱形 r  ...

  9. VSCode插件及用户设置

    第一部分:插件 VSCode内置"emmet"插件,"convert to utf-8"等插件效果!十分强大!代码提示功能特别强悍! 插件地址:点击此处! 推荐 ...

  10. Spring之AOP一

    面向切片式编程不仅在Java中存在,在其他语言也是存在,例如asp.net的管道模型中,可以利用aop来进行自定义一些操作,比如权限认证.日志等.今天主要是引入AOP,具体它涉及到的专有名词先不做解释 ...