算法提高之字串变换

算法提高之字串变换

  • 核心思想:双向广搜

    • 双向bfs 建立两个队列 一起bfs到中间态
cpp 复制代码
  #include <iostream>
  #include <cstring>
  #include <algorithm>
  #include <queue>
  #include <unordered_map>
  
  using namespace std;
  const int N = 6;
  
  int n;
  string A,B;
  string a[N],b[N];
  
  int extend(queue<string>& q, unordered_map<string, int>&da, unordered_map<string, int>& db, 
      string a[N], string b[N])
  {
      int d = da[q.front()];  //确定当前层数
      while(q.size() && da[q.front()] == d)  //如果是同一层的就搜
      {
          auto t = q.front();
          q.pop();
           
          for(int i=0;i<n;i++)  //遍历所有规则
          {
              for(int j=0;j<t.size();j++)
              {
                  if(t.substr(j,a[i].size()) == a[i])  //有相应的子串
                  {
                      //构造新的字符串
                      string r = t.substr(0,j) + b[i] + t.substr(j+a[i].size());
                      if(db.count(r)) return da[t] + db[r] + 1;  //如果b中已经搜到过
                      if(da.count(r)) continue;
                      da[r] = da[t] + 1;
                      q.push(r);
                  }
              }
          }
      }
      return 11;
  }
  int bfs()
  {
      if(A == B) return 0;
      queue<string> qa,qb;
      unordered_map<string,int> da,db;
      
      qa.push(A), qb.push(B);
      da[A] = db[B] = 0;
      int step = 0;  //记录步数 如果超过10 直接return -1
      while(qa.size() && qb.size())
      {
          int t;
          //优先扩展长度短的那个
          if(qa.size()<qb.size()) t = extend(qa,da,db,a,b);  //注意规则是a->b
          else t = extend(qb,db,da,b,a);  //规则是b->a 反向
          
          if(t <= 10) return t;  //没找到之前会返回一个>10的数
          if(++ step == 10) return -1;
      }
      return -1;
  }
  int main()
  {
      cin>>A>>B;
      while(cin>>a[n]>>b[n]) n++;
      
      int t = bfs();
      if (t == -1) puts("NO ANSWER!");
      else cout << t << endl;
  
  }
相关推荐
满怀冰雪3 小时前
第05篇-滑动窗口算法-一套模板解决子串与子数组问题
java·算法
叫我:松哥3 小时前
基于LSTM与ARIMA的城市空气质量分析与预测系统
人工智能·python·rnn·算法·机器学习·flask·lstm
j7~3 小时前
【C++】模板初阶--函数模板,类模板详解
数据结构·c++·算法·函数模板·类模板·函数模板实例化
无限码力3 小时前
阿里算法岗 0530笔试真题 - 寻找满足条件的最优子序列
算法·阿里笔试真题·阿里机试真题·阿里算法岗笔试真题·阿里算法题
@小阿宝3 小时前
机器人正向逆向运动学
算法·机器人
小雨下雨的雨3 小时前
数独算法与求解器鸿蒙PC Electron框架完成深度解析
javascript·人工智能·算法·游戏·华为·electron·鸿蒙系统
HZ·湘怡3 小时前
数据结构之排序算法 (1)--插入排序
c语言·数据结构·算法·排序算法
ouliten3 小时前
[Triton笔记7]融合注意力 (Fused Attention)
人工智能·笔记·算法
开源Z3 小时前
LeetCode 238 · 除自身以外数组的乘积:左右两遍扫描,不用除法
算法·leetcode
BAGAE3 小时前
FEC-RS前向纠错编码理论及工程实施研究
c语言·c++·qt·算法·决策树·链表