題目描述
這道題實際上就是給你乙個字串,然後給你一些變換規則,問最小需要多少步數可以到達最終的那個字串;
這道題呢,實際上是不應該用stl的,因為畢竟2023年stl才解禁,於是寫了乙個hash來代替set,目的是使乙個子串不重複進隊(但考慮到佇列不好實現,便沒有手寫佇列)
直接上**:
#include
#define ll long long
using
namespace std;
const
int mod1=
16927
;const
int mod2=
998244353
;queue q;
queue <
int> cnt;
const
int n=6+
5;string a[n]
;string b[n]
;string s;
string t;
int n;
struct node
node()
;};vector v[mod1]
;int
get_hash_key
(const string &letter,
const
int&mod)
intfind
(const string &w)
}return0;
}void
insert
(const string &w)
} v[key1]
.push_back
(node
(key1,w));
return;}
intbfs()
}if(flag)}}
}return-1
;}intmain()
洛谷p1032 字串變換 (bfs)
題目概述 字串的子串 必須連續與子串行不同 有至多六種變化規則,若在10步 包含10步 以內能將a變換為b,則輸出最少的變換步數 否則輸出 no answer 題目分析 ac include using namespace std mapint mp 從前出現過的字串不能再次出現 廣度搜尋樹,第一次...
BFS 洛谷 P1032 字串變換
年輕人切忌旋入技術細節漩渦,那是無底之洞 zeo 基礎bfs加一堆字串處理細節 逐個比較是否可替換 替換時把字元拆成三段 前 要替換的 後 根據string 特性 前 替換的 後 可得操作完畢後串 步數壓入佇列繼續bfs map 進行判重 坑的不行 寫的想吐 沒感到任何技術提公升 include i...
洛谷P1032 字串變換 bfs
題意 給定乙個原字串和目標字串,以及幾個字串變換的規則。問能否根據這幾個規則在十步之內把原字串變為目標字串。思路 bfs,佇列維護字串和所經過的步驟這樣乙個二元組而不是簡單的字串。每一次取出乙個字串,用所給的規則進行變換得到新的字串。由於字串中可能有多次匹配,所以用vector存每一次匹配的開始位置...