啊本来以为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. BST 解析 (一)

    这篇博文主要初步介绍Binary Search Tree(BST)的一些基本功能以及应用场景,由于BST的相关知识比较多,下一节会接着补充BST的一些功能.这一节主要分为以下三个要素: BST 的定义 ...

  2. 题目1083:特殊乘法-九度oj

    题目描述: 写个算法,对2个小于1000000000的输入,求结果. 特殊乘法举例:123 * 45 = 1*4 +1*5 +2*4 +2*5 +3*4+3*5 输入: 两个小于1000000000的 ...

  3. mysql初体验

    1.mysql数据库: 数据库----文件夹 数据表----文件 数据数据行---文件中的一行数据2. 初始: show databases; 查看当前mysql都有那些数据库,也就是根目录有哪些文件 ...

  4. JSP4(内置对象)

    一.超级链接传值问题传值: <a href="href1.jsp?id=1&name=pkd&age=40">This is my JSP page. ...

  5. 【Spring】多数据源导致自动化配置失败问题

    一.问题描述 笔者根据需求在开发过程中,需要在原项目的基础上(单数据源),新增一个数据源C,根据C数据源来实现业务.至于为什么不新建一个项目,大概是因为这只是个小功能,访问量不大,不需要单独申请个服务 ...

  6. node.js之fs模块

    一.fs模块的mkdir函数,创建文件夹 var http = require("http"); var fs = require("fs"); var ser ...

  7. 基于Jmeter的接口自动化测试实践

    在去年实施了一年的三端(PC.无线M站.无线APP[Android.IOS])后,今年7月份开始,我们开始进行接口自动化的实施,目前已完成了整个框架的搭建以及接口的持续测试集成.今天做个简单的分享. ...

  8. Linux 两台服务器之间传输文件和文件夹

    今天处理一个项目要迁移的问题,突然发现这么多图片怎么移过去,可能第一时间想到的是先从这台服务器下载下来,然后再上传到另外一台服务器上面去,这个方法确实是可行,但是实在是太费时间了,今天我就教大家怎么快 ...

  9. PHP中的会话控制

    了解HTTP(超文本传输协议)可以知道,它采用请求与响应的模式,最大的特点就是无连接无状态. 无连接:每次连接仅处理一个客户端的请求,得到服务器响应后,连接就结束了 无状态:每个请求都是独立的,服务器 ...

  10. javaweb学习总结(五)——Servlet开发(一)(转)

    转载自 http://www.cnblogs.com/xdp-gacl/p/3760336.html 一.Servlet简介 Servlet是sun公司提供的一门用于开发动态web资源的技术. Sun ...