P1032 字串变换(bfs)
https://www.luogu.org/problemnew/show/P1032
題目描述
已知有兩個(gè)字串A,BA,B及一組字串變換的規(guī)則(至多66個(gè)規(guī)則):
規(guī)則的含義為:在 A中的子串A 1
?可以變換為 B 1,A 2可以變換為B 2
? …。
例如:A='abcd'B='xyz'
變換規(guī)則為:
‘a(chǎn)bc’->‘xu’‘ud’->‘y’‘y’->‘yz’則此時(shí),A可以經(jīng)過一系列的變換變?yōu)锽,其變換的過程為:
‘a(chǎn)bcd’->‘xud’->‘xy’->‘xyz’共進(jìn)行了3次變換,使得AA變換為BB。
輸入輸出格式
輸入格式:
輸入格式如下:
|-> 變換規(guī)則
… … /
所有字符串長(zhǎng)度的上限為20。
輸出格式:
輸出至屏幕。格式如下:
若在10步(包含10步)以內(nèi)能將A變換為B,則輸出最少的變換步數(shù);否則輸出"NO ANSWER!"
輸入輸出樣例
輸入樣例#1:
輸出樣例#1:
3ac_code:
/*
每個(gè)點(diǎn)是一個(gè)字符串,想到用map標(biāo)記~
之前用dfs做只有60分,然后第一次用bfs做80分,最后組數(shù)據(jù)WA
WA的點(diǎn)就是,沒有考慮到一個(gè)串對(duì)于一種轉(zhuǎn)換規(guī)則可能會(huì)有多個(gè)位置可變,而他們都是1步到達(dá):
比如:
所以對(duì)于原串不是找到一處匹配的就變換后進(jìn)行下個(gè)規(guī)則
而是繼續(xù)對(duì)于這個(gè)規(guī)則找找看一下有沒有其他地方可以匹配
so對(duì)于查詢是否有可以使用轉(zhuǎn)換規(guī)則時(shí)要用while
還有對(duì)于輸入,它規(guī)則個(gè)數(shù)是不確定的,可以用ctrl+z結(jié)束輸入,但是要記錄到底用多少條規(guī)則
*/
總結(jié)
以上是生活随笔為你收集整理的P1032 字串变换(bfs)的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: P1060 开心的金明(01背包)
- 下一篇: gcc里的__builtin_..