题目: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. CSS——padding

    padding是盒子内容与边框的距离. padding:10px;/*上下左右都是10px*/ padding:10px 20px;/*上下是10px 左右是20px*/ padding:10px 2 ...

  2. C# 配置文件ini操作类

    // [ DllImport ( "kernel32" ) ] //private static extern long WritePrivateProfileString ( s ...

  3. 9、scala面向对象编程之继承

    1.  extends 2.override 和super 3.override field 4.isInstanceOf和asInstanceOf 5.getClass和classOf 6.使用模式 ...

  4. (转)分布式文件存储FastDFS(二)FastDFS安装

    http://blog.csdn.net/xingjiarong/article/details/50559761 在前面的一篇中,我们分析了FastDFS的架构,知道了FastDFS是由客户端,跟踪 ...

  5. UICollectionViewFlowLayout & UICollectionViewDelegateFlowLayout

    A concrete layout object that organizes items into a grid with optional header and footer views for ...

  6. python包与模块

    Python基础-包与模块 摘要 为重用以及更好的维护代码,Python使用了模块与包:一个Python文件就是一个模块,包是组织模块的特殊目录(包含__init__.py文件). 模块搜索路径,Py ...

  7. [SQL Server] 常用sql脚本

    1.添加表 GO IF NOT EXISTS(SELECT * FROM sys.tables WHERE name='table_name') BEGIN CREATE TABLE [dbo].[t ...

  8. 五、Scrapy中Item Pipeline的用法

    本文转载自以下链接: https://scrapy-chs.readthedocs.io/zh_CN/latest/topics/item-pipeline.html https://doc.scra ...

  9. 如何在redhat 7上安装VNC服务器

    平时我们基本上都是用xshell或者用putty远程我们的linux服务器,如果我们的linux服务器安装了图型化界面那我们又该如何远程使用我们的图形化界面呢?下面我们用vnc来实现远程我们的linu ...

  10. VMware Workstation 15 安装教程

    注:操作系统必须是64位    软件:360软件管家获取 1.运行下载完成的Vmware Workstation虚拟机软件包. 虚拟机软件的安装向导初始界面 2.在虚拟机软件的安装向导界面单击“下一步 ...