首页 > 其他分享 >洛谷题单指南-搜索-P1032 [NOIP2002 提高组] 字串变换

洛谷题单指南-搜索-P1032 [NOIP2002 提高组] 字串变换

时间:2024-03-08 14:44:34浏览次数:34  
标签:子串 tmp cur NOIP2002 src 洛谷题 pos P1032 替换

原题链接:https://www.luogu.com.cn/problem/P1032

题意解读:要计算子串变换的最少步数,典型的最短路问题,可以通过BFS求解。

解题思路:

思路上比较直观,从给定的字符串开始,找有多少种替换可能,依次进行替换,存入队列,继续BFS,过程中记录替换的次数

但是,有一些细节还需要注意:

1、有多种替换规则,需要逐条尝试

2、对于每一种替换规则,可能有多处可以替换,也需要逐个位置尝试

3、因此每一个替换规则的每一处替换位置,才产生依次替换

其他就是BFS过程中的常规代码。

100分代码:

#include <bits/stdc++.h>
using namespace std;

string a, b;
string src[10], dest[10]; //替换规则:src是寻找的子串,dest是替换的子串
int cnt; //规则数

map<string, bool> flag; //字符串是否出现过
map<string, int> depth; //字符串是经过几次变换来的,也就是路径长度

queue<string> q;

bool bfs(string a)
{
    q.push(a);
    flag[a] = true;
    while(q.size())
    {
        string cur = q.front(); q.pop();
        
        for(int i = 0; i < cnt; i++) //遍历所有替换规则
        {
            int pos = 0;
            vector<int> allpos; //存储包含子串的所有位置,可以替换任意一个
            while(pos < cur.size()) //不断在字符串中找子串,如果找到就在后面继续找,所有子串都要替换掉
            {
                pos = cur.find(src[i], pos); //从pos位置开始找r.first子串
                if(pos >= 0 && pos < cur.size()) //如果找到子串
                {
                    allpos.push_back(pos); //记录子串位置
                    pos += src[i].size(); //寻找的位置移动跳过子串
                }
                else break;
            } 

            for(int j = 0; j < allpos.size(); j++) //对不同位置的子串进行替换
            {
                string tmp = cur; //定义临时变量,后面的替换不影响cur
                tmp.replace(allpos[j], src[i].size(), dest[i]); //替换子串
                if(!flag[tmp]) 
                {
                    depth[tmp] = depth[cur] + 1;
                    if(depth[tmp] > 10) return false;
                    if(tmp == b) return true;
                    q.push(tmp);
                    flag[tmp] = true;
                }
            } 
        }
    }

    return false;
}

int main()
{
    cin >> a >> b;
    while(cin >> src[cnt] >> dest[cnt]) cnt++;
    
    if(bfs(a)) cout << depth[b];
    else cout << "NO ANSWER!";

    return 0;
}

 

标签:子串,tmp,cur,NOIP2002,src,洛谷题,pos,P1032,替换
From: https://www.cnblogs.com/jcwy/p/18060922

相关文章

  • 洛谷题单指南-搜索-P1162 填涂颜色
    原题链接:https://www.luogu.com.cn/problem/P1162题意解读:要把闭合圈内的0填为2,DFS处理即可。解题思路:由于方阵内只有一个闭合圈,所以闭合圈以外的0一定和边缘相连通,只需要从边缘开始,把0的连通块全部标记为2最后再输出时,2输出0,1输出1,0输出2,即可得解。100分代码:#include<bits......
  • 洛谷题单指南-搜索-P2404 自然数的拆分问题
    原题链接:https://www.luogu.com.cn/problem/P2404题意解读:将整数拆成若干数相加,按字母序输出,可以转换成从小到大往数组填数的问题,直到填的数之和等于n。解题思路:通过DFS,每次填一个数,填数时从1~n-1逐个填注意两个条件不能继续DFS:1、将填的数之和超过n2、将填的数小于上一次填......
  • 洛谷题单指南-搜索-P1101 单词方阵
    原题链接:https://www.luogu.com.cn/problem/P1101题意解读:对于方阵中的每一个字符,在8个方向上判断是否和"yizhong"匹配,是一个递归问题。解题思路:用chara[N][N]存储所有字符方阵,用boolb[N][N]标记每个字符是否在任一方向上和yizhong匹配遍历方阵每一字符,如果是'y'则在8个方......
  • 洛谷题单指南-搜索-P1019 [NOIP2000 提高组] 单词接龙
    原题链接:https://www.luogu.com.cn/problem/P1019题意解读:要计算接龙能得到的最长字符串,可以通过DFS暴搜所有可能的接龙方案解题思路:DFS的关键在于两个判断:1、下一个单词是否可以和上一个单词接龙,最短公共长度是多少(只需要看两个单词的最短公共长度,这样能保证接龙更长)2、单词......
  • 洛谷题单指南-搜索-P1605 迷宫
    原题链接:https://www.luogu.com.cn/problem/P1605题意解读:从起点走到终点的方案数,DFS可遍历所有情况。解题思路:在DFS过程中,有两种标记墙:不能访问已访问过的,不能重复访问定义数组inta[N][N]表示迷宫,1是墙或者已访问过的,0是可以通过的。100分代码:#include<bits/stdc++.h>......
  • 洛谷题单指南-搜索-P1433 吃奶酪
    原题链接:https://www.luogu.com.cn/problem/P1433题意解读:计算经过所有奶酪一次的总路径最短,可以采用dfs、dp等方法。解题思路:最直接的思路是DFS,暴搜所有的路径方案,计算最小距离,n最大是15,复杂度为15!≈10^12,必定会超时,先保证正确性,得到部分分:50分代码:#include<bits/stdc++.h......
  • 洛谷题单指南-搜索-P2895 [USACO08FEB] Meteor Shower S
    原题链接:https://www.luogu.com.cn/problem/P2895题意解读:所谓安全格子,就是在所有流星坠落之后,没有被烧焦的格子,要计算从起点到这些格子任一一个的最短路径,BFS可以解决。解题思路:1、读取数据,先把所有流星坠落点以及周围被烧焦的格子进行标记,得到安全格子2、从起点开始BFS,每走......
  • 洛谷题单指南-搜索-P1135 奇怪的电梯
    原题链接:https://www.luogu.com.cn/problem/P1135题意解读:计算A到B至少要按几次电梯,本质上就是求A到B的最短路径,可以通过BFS解决。解题思路:位于每一层,有两种选择:向上、向下BFS搜索直接从A找到B,每扩展一层,层数+1,层数即按电梯次数100分代码:#include<bits/stdc++.h>usingnam......
  • 洛谷题单指南-搜索-P1443 马的遍历
    原题链接:https://www.luogu.com.cn/problem/P1443题意解读:无论是国际象棋还是中国象棋,马的活动范围都是一样的:只不过国际象棋棋子是在格子中,中国象棋棋子是在交点,坐标的变化方式是一样的,根据此活动范围,计算马到达每一个点的最短路径。解题思路:根据马的活动范围,在棋盘内进行B......
  • 洛谷题单指南-搜索-P2392 kkksc03考前临时抱佛脚
    原题链接:https://www.luogu.com.cn/problem/P2392解题思路:参考https://www.cnblogs.com/jcwy/p/18003097前面已经给出了二进制法的代码,这里给出DFS的代码100分代码:#include<bits/stdc++.h>usingnamespacestd;constintN=25;ints1,s2,s3,s4;inta[N],b[N],c[......