题目:https://www.luogu.org/problemnew/show/P1032

字符串好复杂...先写了个 dfs ,RE一个点TLE一个点,不知该怎么改了...

#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
char a[],b[],c[][],d[][];
int n,ans=,inf=;
bool ck(char x[],int l1,int i,int j)
{
int l2=strlen(c[j]);
if(l1-i<l2)return ;
for(int t=;t<l2&&i+t<l1;t++)
if(x[i+t]!=c[j][t])return ;
return ;
}
bool cmp(char x[],int l1)
{
// int l1=x.length(),l2=b.length();
int l2=strlen(b);
if(l1!=l2)return ;
for(int i=;i<l1;i++)if(x[i]!=b[i])return ;
return ;
}
void print(char x[],int l)
{
printf("%d ",l);
for(int i=;i<l;i++)printf("%c",x[i]);
printf("\n");
}
void dfs(char x[],int s,int l)
{
if(cmp(x,l)){ans=min(ans,s); return;}
if(s>=)return;
char nxt[];
for(int i=;i<l;i++)
{
for(int j=;j<n;j++)
if(ck(x,l,i,j))
{
cout<<j<<endl;
int l1=strlen(c[j]),l2=strlen(d[j]),ln=;
for(int k=;k<i;k++)nxt[ln++]=x[k];
for(int k=;k<l2;k++)nxt[ln++]=d[j][k];
for(int k=i+l1;k<l;k++)nxt[ln++]=x[k];
dfs(nxt,s+,ln);
}
}
}
int main()
{
cin>>a; cin>>b; n=;
while(cin>>c[n]>>d[n])n++;
// while(~scanf("%s",&t))
// c[++n]=t,scanf("%s",&d[n]);
dfs(a,,strlen(a));
if(ans==inf)printf("NO ANSWER!");
else printf("%d\n",ans);
return ;
}

dfs

看到大家都是 bfs,确实找最小步数的话应该是 bfs 呢;

用了好多 STL,学到了...

思路没什么,就是不太好写,使用 STL 感觉很方便。

代码如下:

#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<queue>
#include<map>
using namespace std;
int n;
string a,b,c[],d[];
map<string,int>mp;
queue<pair<string,int> >q;
int main()
{
cin>>a>>b;
while(cin>>c[++n])cin>>d[n];
n--; mp[a]=;
q.push(make_pair(a,));
while(q.size())
{
string s=q.front().first; int t=q.front().second; q.pop();
int l=s.length();
if(t>)break;
for(int i=;i<=n;i++)
{
int l2=c[i].length();
for(int j=;j<=l-l2;j++)
{
if(s.substr(j,l2)!=c[i])continue;
string ns; ns.clear();//
if(j)ns+=s.substr(,j);//(起点,起点开始的长度)
ns+=d[i];
if(j+l2<l)ns+=s.substr(j+l2,l-j-l2+);
if(ns==b){printf("%d\n",t+); return ;}
if(mp.find(ns)==mp.end())
{
mp[ns]=t+;
q.push(make_pair(ns,t+));
}
}
}
}
printf("NO ANSWER!");
return ;
}

洛谷 P1032 [ NOIP 2002 ] 字串变换 —— 字符串+bfs的更多相关文章

  1. [COGS 0065][NOIP 2002] 字串变换

    65. [NOIP2002] 字串变换 ★★   输入文件:string.in   输出文件:string.out   简单对比时间限制:1 s   内存限制:128 MB [问题描述] 已知有两个字 ...

  2. P1032 字串变换 字符串BFS

    题目描述 已知有两个字串A,BA,B及一组字串变换的规则(至多66个规则): A_1A1​ ->B_1B1​ A_2A2​ -> B_2B2​ 规则的含义为:在 AA中的子串 A_1A1​ ...

  3. 【题解】洛谷P1032 [NOIP2002TG]字串变换(BFS+字符串)

    洛谷P1032:https://www.luogu.org/problemnew/show/P1032 思路 初看题目觉得挺简单的一道题 但是仔细想了一下发现实现代码挺麻烦的 而且2002年的毒瘤输入 ...

  4. 「NOIP2002」「Codevs1099」 字串变换(BFS

    1099 字串变换 2002年NOIP全国联赛提高组 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 黄金 Gold   题目描述 Description 已知有两个字串 $A$, ...

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

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

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

    题目传送门 我即使是死了,钉在棺材里了,也要在墓里,用这腐朽的声带喊出 STL大法好 这题最麻烦的其实是处理字符串,真正的搜索部分我个人认为也就只有橙题或黄题的难度.而处理字符串,正如前面所说,STL ...

  7. codevs1099字串变换(Bfs)

    /* 最少步数问题 妥妥的Bfs 很显然队列里存的是串(可能存个数也可以 就像8数码那样) 然后每次队首元素弄出来 能换的都换一遍 最后每次换完的新串入队前先判断到头了没 最后说一句 String大法 ...

  8. [洛谷P1032] 字串变换

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

  9. 洛谷 P1032 字串变换题解

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

随机推荐

  1. JS高级——原型链

    构造函数 构造函数是特殊的函数,里面没有returen返回值 new的过程中,会自动将对象返回,不需要return new的过程中,会执行函数中的代码,会将创建的对象赋值给构造函数中的this 基本概 ...

  2. html5——css选择器

    复习 div>p: 子代 div+p:div后面相邻的第一个p div~p: div后面所有的兄弟p 属性选择器 标志:[]:区别于id选择器:#,区别于类名选择器:. 特殊符号:^:开头    ...

  3. JS——select标签

    <!DOCTYPE html> <html> <head lang="en"> <meta charset="UTF-8&quo ...

  4. LINUX - 硬链接 软连接

    ---------------------------------------------------------------------------------------------------- ...

  5. HTML5本地存储——Web SQL Database与indexedDB

    虽然在HTML5 WebStorage介绍了html5本地存储的Local Storage和Session Storage,这两个是以键值对存储的解决方案,存储少量数据结构很有用,但是对于大量结构化数 ...

  6. Pyspider爬虫简单框架——链家网

    pyspider 目录 pyspider简单介绍 pyspider的使用 实战 pyspider简单介绍 一个国人编写的强大的网络爬虫系统并带有强大的WebUI.采用Python语言编写,分布式架构, ...

  7. ssh_整合总结

    开场白:首先,我先帮大家整理一下思路 准备: 数据库,表,数据 jar 包准备 Hibernate 基本jar 包 C3p0 数据库连接池 Spring AOP 基本包 Spring Ioc 基本包 ...

  8. mongoDB全文索引

    相关文章:php使用Coreseek实现全文索引 Introduction Mongo provides some functionality that is useful for text sear ...

  9. ESXi License过期解决办法

    http://blog.sina.com.cn/s/blog_538439270101pqls.html

  10. pyenv-virtualenv环境搭建

    搞了个新服务器,搭个python环境 安装pyenv 直接上懒人脚本,不怕麻烦想手动装的就麻烦您自己查吧~ curl -L https://raw.githubusercontent.com/yyuu ...