题目: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. jQuery——入口函数

    中文网 http://www.css88.com/jqapi-1.9/ 版本兼容问题 版本一:1.x版本,兼容IE678 版本二:2.x版本,不兼容IE678 入口函数区别 <script> ...

  2. python 分割文件、组合文件

    import glob big_file = open('index.sql', 'rb') bak_file = 'index_bak' i = 1 while True: chunk = big_ ...

  3. JavaScript:颜色辨别

    <script> //参考文章:http://www.cnblogs.com/xuechenlei/p/5940729.html //游戏页面:http://www.webhek.com/ ...

  4. Python 之pygame飞机游戏

    import pygame from pygame.locals import * import time import random # 我机 class HeroPlane(object): de ...

  5. querySelector

     this.el.nativeElement.querySelector import {Component, ElementRef, OnInit} from '@angular/core'; 

  6. 【转】下载对应内核版本的asmlib

    登陆oracle官网: http://www.oracle.com/ 注意:查询前,需要注册一个OTN账号,注册是免费的. 首页直接搜索“ASMLib”关键词(注意大小写) 进入搜索界面,点击第一项即 ...

  7. enote笔记语言(5)——其他

    章节:其他   ((主:单词))                               用来醒目地强调这个句子中哪个词语作主语 sentence:                         ...

  8. Django REST framework 分页

    三种分页:根据页码.根据索引.根据加密 http://www.xx.com/courses/?page=1&size=10 http://www.xx.com/courses/?offset= ...

  9. 亚马逊免费服务器搭建Discuz!论坛过程(四)

    上述命令还可能因缺少包引发其他错误: 如果出错则安装对应的包即可. 以下供参考: yum install libxml2 yum install libxml2-devel -y yum instal ...

  10. Silverlight之我见——DataGrid数据验证

    <UserControl x:Class="DataValidationSample.MainPage" xmlns="http://schemas.microso ...