洛谷 P1032 [ NOIP 2002 ] 字串变换 —— 字符串+bfs
题目: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的更多相关文章
- [COGS 0065][NOIP 2002] 字串变换
65. [NOIP2002] 字串变换 ★★ 输入文件:string.in 输出文件:string.out 简单对比时间限制:1 s 内存限制:128 MB [问题描述] 已知有两个字 ...
- P1032 字串变换 字符串BFS
题目描述 已知有两个字串A,BA,B及一组字串变换的规则(至多66个规则): A_1A1 ->B_1B1 A_2A2 -> B_2B2 规则的含义为:在 AA中的子串 A_1A1 ...
- 【题解】洛谷P1032 [NOIP2002TG]字串变换(BFS+字符串)
洛谷P1032:https://www.luogu.org/problemnew/show/P1032 思路 初看题目觉得挺简单的一道题 但是仔细想了一下发现实现代码挺麻烦的 而且2002年的毒瘤输入 ...
- 「NOIP2002」「Codevs1099」 字串变换(BFS
1099 字串变换 2002年NOIP全国联赛提高组 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 黄金 Gold 题目描述 Description 已知有两个字串 $A$, ...
- 洛谷P1032 字串变换【bfs】
题目链接:https://www.luogu.org/problemnew/show/P1032 题意: 给定一个原字符串和目标字符串,以及几个字符串变换的规则. 问能否根据这几个规则在十步之内把原字 ...
- 洛谷 P1032 字串变换 (BFS)
题目传送门 我即使是死了,钉在棺材里了,也要在墓里,用这腐朽的声带喊出 STL大法好 这题最麻烦的其实是处理字符串,真正的搜索部分我个人认为也就只有橙题或黄题的难度.而处理字符串,正如前面所说,STL ...
- codevs1099字串变换(Bfs)
/* 最少步数问题 妥妥的Bfs 很显然队列里存的是串(可能存个数也可以 就像8数码那样) 然后每次队首元素弄出来 能换的都换一遍 最后每次换完的新串入队前先判断到头了没 最后说一句 String大法 ...
- [洛谷P1032] 字串变换
洛谷题目链接:字串变换 题目描述 已知有两个字串 A, B 及一组字串变换的规则(至多6个规则): A1 -> B1 A2 -> B2 规则的含义为:在 A$中的子串 A1 可以变换为 B ...
- 洛谷 P1032 字串变换题解
题目链接:https://www.luogu.org/problem/P1032 题目描述 已知有两个字串A,BA,B及一组字串变换的规则(至多66个规则): A_1A1 ->B_1B1 A ...
随机推荐
- 编写高质量的js之恰当选用if和switch
switch结构中存在很多限制,存在这些限制的主要目的是提高多重分支结构的执行效率.因此,如果能够使用switch结构,就不要选择if结构. 无论是使用if结构,还是使用switch结构,应该确保下面 ...
- html5——多列布局
基本概念 1.多列布局类似报纸或杂志中的排版方式,上要用以控制大篇幅文本. 2.跨列属性可以控制横跨列的数量 /*列数*/ -webkit-column-count: ; /*分割线*/ -webki ...
- SQl基本操作——视图
视图适合频繁查询的表:将一个查询结果作为虚拟表提供给开发人员.安全性高,视图只能查询不能修改,它是一张虚拟表.查询方便,逻辑清晰,但是性能低,一般情况下不如自己写sql语句. --创建视图 creat ...
- 转载:使用FileReader对象的readAsDataURL方法来读取图像文件
文章转载自:http://blog.okbase.net/jquery2000/archive/1296.html: FileReader对象的readAsDataURL方法可以将读取到的文件编码成D ...
- DNS详细解析过程【转】
转自:http://blog.csdn.net/crazw/article/details/8986504 先说一下DNS的几个基本概念: 一. 根域 就是所谓的“.”,其实我们的网址www.baid ...
- node.js的初级使用
node.js的初级使用 作为一个全栈开发员怎么能不会node.js了?至少得会用node搭载环境吧!话不多说直接开干! 一.下载与安装: 官网:http://nodejs.cn/ 中文文档:http ...
- Ajax基本写法
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...
- img标签和background-image的区别和具体使用时机
最近在使用图片过程中,纠结到底使用img标签还是使用background-image属性,翻阅资料和百度后作出下列理解. 简单来说img是内容部分的东西,background-image是修饰性的东西 ...
- flask_model防止循环引用
1 首先介绍app-model的循环引用 https://www.cnblogs.com/fuzzier/p/7920645.html 2 解决方式 https://www.cnblogs.com/f ...
- selenium等待
简介 在selenium操作浏览器的过程中,每一次请求url,selenium都会等待页面加载完成以后, 才会将操作权限在交给我们的程序. 但是,由于ajax和各种JS代码的异步加载问题,当一个页面被 ...