啊本来以为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. iis7 部署网站 403错误

    C:\Windows\Microsoft.NET\Framework\v4.0.30319\aspnet_regiis.exe -i 403 - 禁止访问: 访问被拒绝. 您无权使用所提供的凭据查看此 ...

  2. TP框架中内置查询IP函数

    系统内置了get_client_ip方法用于获取客户端的IP地址,使用示例: $ip = get_client_ip(); 如果要支持IP定位功能,需要使用扩展类库Org\Net\IpLocation ...

  3. Activity讲解

    Activity Activity 是 Android 应用的重要组成单元之一(另外三个是 Service.BroadcastReceiver 和 ContentProvider),而 Activit ...

  4. Servlet,JSP 中的中文乱码问题以及解决方案

    问题描述: 在Servlet,JSP 传递数据中,英文无影响,而中文有时候就会出现乱码. 解决方案: 相同的编码: 同一个项目中的每个文件应当设置和保存相同的编码方式,如: html中 <met ...

  5. [WPF]本地化入门

    1. 前言 WPF的本地化是个很常见的功能,我做过的WPF程序大部分都实现了本地化(不管最终有没有用到).通常本地化有以下几点需求: 在程序启动时根据CultureInfo.CurrentUICult ...

  6. haproxy,tomcat.apache记录用户真实IP

    Haproxy配置: default加入: option httpclose option forwardfor Tomcat配置: server.xml中添加 prefix="localh ...

  7. Java二分法

    public class Dichotomy {        //定义查找次数    static int count = 0;        public static void main(Str ...

  8. 关于 AspNet Core 的配置文件 与VS2017 安装

    下面链接 是VS2017 安装EXE 我现在装过了就不去截图演示了,有哪位不理解的可以@我. 链接:https://pan.baidu.com/s/1hsjGuJq 密码:ug59 1.今天我给大家带 ...

  9. Mysql的安装和图形化界面的使用

    访问mysql网址:https://dev.mysql.com/ 下面需要登录你的oracle账号进行下载就好~ 下载之后是一解压包形式存在的~ 解压之后的文件 这里我新建了my.ini的文件~将my ...

  10. Java IO(3)非阻塞式输入输出(NIO)

    在上篇<Java IO(2)阻塞式输入输出(BIO)>的末尾谈到了什么是阻塞式输入输出,通过Socket编程对其有了大致了解.现在再重新回顾梳理一下,对于只有一个“客户端”和一个“服务器端 ...