8.23 - hard - 98

514. Freedom Trail

手寫了TLE版本固灵,加了一些memory捅伤,不過還是TLE∥撞#基本思路是對(duì)的丛忆,只是有一點(diǎn)問題,不用找到所有的值仍秤,只需要針對(duì)某一個(gè)index熄诡,找到之前的第一個(gè)和之后的第一個(gè)就可以了。

class Solution(object):
    def findRotateSteps(self, ring, key):
        """
        :type ring: str
        :type key: str
        :rtype: int
        """
        ring = list(ring)
        return self.search(ring, key, 0, {}) + len(key)
        
    
    def search(self, ring, key, pos, m):
        if pos == len(key):
            return 0
        if str(ring)+str(pos) in m:
            return m[str(ring)+str(pos)]
        res = sys.maxint
        for i in range(len(ring)):
            if ring[i] == key[pos]:
                new_ring = ring[i:] + ring[:i]
                res = min(res, self.search(new_ring, key, pos + 1, m)+min(i, len(ring)-i))
        m[str(ring)+str(pos)] = res
        return res
class Solution(object):
    def findRotateSteps(self, ring, key):
        """
        :type ring: str
        :type key: str
        :rtype: int
        """
        if not ring or not key:
            return 0
        mem = [[0 for _ in range(len(key))] for _ in range(len(ring))]
        return self.findShortest(ring, 0, key, 0, mem)
    
    def findShortest(self, arr, p, key, pos, mem):
        if pos == len(key):
            return 0
        if mem[p][pos] > 0:
            return mem[p][pos]
        c1 = c2 = 0
        i = j = p
        # from pericular position of p, find 
        while arr[i] != key[pos]:
            i = (i+1) % len(arr)
            c1 += 1
            
        while arr[j] != key[pos]:
            j= (j-1+len(arr)) % len(arr)
            c2 += 1
        r1 = self.findShortest(arr, i, key, pos+1, mem) + c1 + 1
        r2 = self.findShortest(arr, j, key, pos+1, mem) + c2 + 1
        mem[p][pos] = min(r1,r2)
        return mem[p][pos]
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末诗力,一起剝皮案震驚了整個(gè)濱河市凰浮,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌苇本,老刑警劉巖袜茧,帶你破解...
    沈念sama閱讀 222,000評(píng)論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異瓣窄,居然都是意外死亡笛厦,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,745評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門俺夕,熙熙樓的掌柜王于貴愁眉苦臉地迎上來裳凸,“玉大人,你說我怎么就攤上這事啥么〉俏瑁” “怎么了?”我有些...
    開封第一講書人閱讀 168,561評(píng)論 0 360
  • 文/不壞的土叔 我叫張陵悬荣,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我疙剑,道長(zhǎng)氯迂,這世上最難降的妖魔是什么践叠? 我笑而不...
    開封第一講書人閱讀 59,782評(píng)論 1 298
  • 正文 為了忘掉前任,我火速辦了婚禮嚼蚀,結(jié)果婚禮上禁灼,老公的妹妹穿的比我還像新娘。我一直安慰自己轿曙,他們只是感情好弄捕,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,798評(píng)論 6 397
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著导帝,像睡著了一般守谓。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上您单,一...
    開封第一講書人閱讀 52,394評(píng)論 1 310
  • 那天斋荞,我揣著相機(jī)與錄音,去河邊找鬼虐秦。 笑死平酿,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的悦陋。 我是一名探鬼主播蜈彼,決...
    沈念sama閱讀 40,952評(píng)論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼俺驶!你這毒婦竟也來了幸逆?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,852評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤痒钝,失蹤者是張志新(化名)和其女友劉穎秉颗,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體送矩,經(jīng)...
    沈念sama閱讀 46,409評(píng)論 1 318
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡蚕甥,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,483評(píng)論 3 341
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了栋荸。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片菇怀。...
    茶點(diǎn)故事閱讀 40,615評(píng)論 1 352
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖晌块,靈堂內(nèi)的尸體忽然破棺而出爱沟,到底是詐尸還是另有隱情,我是刑警寧澤匆背,帶...
    沈念sama閱讀 36,303評(píng)論 5 350
  • 正文 年R本政府宣布呼伸,位于F島的核電站,受9級(jí)特大地震影響钝尸,放射性物質(zhì)發(fā)生泄漏括享。R本人自食惡果不足惜搂根,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,979評(píng)論 3 334
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望铃辖。 院中可真熱鬧剩愧,春花似錦、人聲如沸娇斩。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,470評(píng)論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽犬第。三九已至锦积,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間瓶殃,已是汗流浹背充包。 一陣腳步聲響...
    開封第一講書人閱讀 33,571評(píng)論 1 272
  • 我被黑心中介騙來泰國(guó)打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留遥椿,地道東北人基矮。 一個(gè)月前我還...
    沈念sama閱讀 49,041評(píng)論 3 377
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像冠场,于是被迫代替她去往敵國(guó)和親家浇。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,630評(píng)論 2 359

推薦閱讀更多精彩內(nèi)容

  • Android 自定義View的各種姿勢(shì)1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 172,303評(píng)論 25 707
  • 一碴裙、源題QUESTION 36Your database is open and the LISTENER lis...
    貓貓_tomluo閱讀 1,239評(píng)論 0 2
  • 背景 一年多以前我在知乎上答了有關(guān)LeetCode的問題, 分享了一些自己做題目的經(jīng)驗(yàn)钢悲。 張土汪:刷leetcod...
    土汪閱讀 12,748評(píng)論 0 33
  • 有時(shí),望著眼前的平靜的一切舔株,我會(huì)害怕莺琳!回首過去數(shù)年,日子都太過平靜载慈,還沒經(jīng)歷多少苦難惭等,可人生哪有那么容易讓你過,我...
    木易allie閱讀 175評(píng)論 0 1
  • 我不記得昨天晚上夢(mèng)到了什么办铡,只是早晨起床畫眉時(shí)辞做,突然很想秦哲,以至于畫的一團(tuán)遭寡具,還遲到了20分鐘秤茅。 我總是認(rèn)為秦哲...
    如果玻璃會(huì)說話z閱讀 351評(píng)論 0 0