啊本来以为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. 杭电ACM题单

    杭电acm题目分类版本1 1002 简单的大数 1003 DP经典问题,最大连续子段和 1004 简单题 1005 找规律(循环点) 1006 感觉有点BT的题,我到现在还没过 1007 经典问题,最 ...

  2. poj2485 highwaysC语言编写

    /*HighwaysTime Limit: 1000MSMemory Limit: 65536KTotal Submissions: 33595Accepted: 15194DescriptionTh ...

  3. jstl--->Core 核心标签库->流程控制

    jstl--->Core 核心标签库->流程控制 -->if.choose.when.otherwise  <c:if>条件判断 语法1:没有本体内容  <c:if ...

  4. heartbeat+DRBD 高可用 双机热备

    heartbeat+DRBD 高可用 双机热备 原创博文http://www.cnblogs.com/elvi/p/7658109.html ## heartbeat+DRBD 高可用 双机热备 # ...

  5. javascript设计模式——命令模式

    前面的话 假设有一个快餐店,而我是该餐厅的点餐服务员,那么我一天的工作应该是这样的:当某位客人点餐或者打来订餐电话后,我会把他的需求都写在清单上,然后交给厨房,客人不用关心是哪些厨师帮他炒菜.餐厅还可 ...

  6. 使用java类破解MyEclipse

    今天在网上查资料的时候无意中发现使用java类破解MyEclipse的注册码问题.跟大家分享一下 1.建立JAVA Project,随便命名,只要符合规则就行 2.在刚刚建好的Project右击src ...

  7. js模拟静态方法

    //模拟静态 var Animal = function(name){ this.name = name; Animal.instanceCounter ++; }; Animal.instanceC ...

  8. JavaSE----基础语法(方法)

    1.8 方法 1.8.1方法的的定义 定义:完毕特定功能的代码块.在非常多语言里面有函数的定义,而在Java中函数被称为方法. 格式: 修饰符 返回值类型 方法名(參数类型 參数名1,參数类型 參数名 ...

  9. Android后台执行的定时器实现

    Android后台运行定时器,方便我们运行定位跟踪等任务需求. 以下简要说明实现Android后台定时器的要点, 文章末尾能够下载到project代码,可直接编译运行. AndroidManifest ...

  10. 參与 Spring 4 中文文档翻译

    參与 Spring 4 中文文档翻译 我们从2014年12月開始翻译Spring 4的框架文档.尽管至今已有一年,可是进度非常慢. 当中一部分原因是由于Spring 文档有1000多页,并且翻译的时候 ...