leetcode514. 自由之路(dp)

電子游戲“輻射4”中,任務“通向自由”要求玩家到達名為“Freedom Trail Ring”的金屬表盤,并使用表盤拼寫特定關鍵詞才能開門。

給定一個字符串 ring,表示刻在外環上的編碼;給定另一個字符串 key,表示需要拼寫的關鍵詞。您需要算出能夠拼寫關鍵詞中所有字符的最少步數。

最初,ring 的第一個字符與12:00方向對齊。您需要順時針或逆時針旋轉 ring 以使 key 的一個字符在 12:00 方向對齊,然后按下中心按鈕,以此逐個拼寫完 key 中的所有字符。

旋轉 ring 拼出 key 字符 key[i] 的階段中:

您可以將 ring 順時針或逆時針旋轉一個位置,計為1步。旋轉的最終目的是將字符串 ring 的一個字符與 12:00 方向對齊,并且這個字符必須等于字符 key[i] 。
如果字符 key[i] 已經對齊到12:00方向,您需要按下中心按鈕進行拼寫,這也將算作 1 步。按完之后,您可以開始拼寫 key 的下一個字符(下一階段), 直至完成所有拼寫。
示例:

輸入: ring = “godding”, key = “gd”
輸出: 4
解釋:
對于 key 的第一個字符 ‘g’,已經在正確的位置, 我們只需要1步來拼寫這個字符。
對于 key 的第二個字符 ‘d’,我們需要逆時針旋轉 ring “godding” 2步使它變成 “ddinggo”。
當然, 我們還需要1步進行拼寫。
因此最終的輸出是 4。

代碼

class Solution {public int findRotateSteps(String ring, String key) {int n=key.length(),m=ring.length();int[][] dp=new int[n][m];List<Integer> [] temp=new ArrayList[26];for(int i=0;i<26;i++)temp[i]=new ArrayList<>();for(int i=0;i<m;i++){temp[ring.charAt(i)-'a'].add(i);}//記錄相同字母在ring中出現的位置for (int i=0;i<n;i++)Arrays.fill(dp[i],0x3f3f3f);for(int c:temp[key.charAt(0)-'a'])dp[0][c]=Math.min(c,m-c)+1;//初始化第一步可能的移動for(int i=1;i<n;i++)for(int j:temp[key.charAt(i)-'a'])//遍歷這一步可能到達的位置for(int k:temp[key.charAt(i-1)-'a'])//遍歷上一步所有可能停留的位置dp[i][j]= Math.min(dp[i][j],Math.min(Math.abs(j-k), m-Math.abs(j-k))+1+dp[i-1][k]);int min=Integer.MAX_VALUE;for(int i=0;i<m;i++)min=Math.min(min,dp[n-1][i]);return min;}
}

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/392674.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/392674.shtml
英文地址,請注明出處:http://en.pswp.cn/news/392674.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

java實現遞歸算法_如何在Java中實現二進制搜索算法而無需遞歸

java實現遞歸算法by javinpaul由javinpaul 流行的二進制搜索算法的迭代實現&#xff0c;用于在排序數組中查找元素。 (An Iterative implementation of the popular binary search algorithm to find an element in a sorted array.) Hello everyone! I have published a lot …

Django 入門項目案例開發(中)

關注微信公眾號&#xff1a;FocusBI 查看更多文章&#xff1b;加QQ群&#xff1a;808774277 獲取學習資料和一起探討問題。 昨天已經描述了如何搭建Django的開發環境&#xff0c;今天描述業務流程&#xff0c;具體我們要實現一個什么樣的業務&#xff1b; 以下的業務都是假設的…

縱橫公路造價軟件學習_通遼分公司組織開展2020年 養護工程造價預算培訓

為進一步提高養護員工業務水平和業務素質&#xff0c;提升熟練掌握信息化公路工程造價預算&#xff0c;11月5日&#xff0d;11月8日期間,通遼分公司組織開展了2020年養護工程造價預算培訓。養護科全體人員、基層所站統計人員共計16人參加培訓。本次培訓邀請了縱橫公路工程造價管…

java 生成二維碼

一步一步用 java 設計生成二維碼 轉至 http://blog.sina.com.cn/s/blog_5a6efa330102v1lb.html 在物聯網的時代&#xff0c;二維碼是個很重要的東西了&#xff0c;現在無論什么東西都要搞個二維碼標志&#xff0c;唯恐落伍&#xff0c;就差人沒有用二維碼識別了。也許有一天生分…

leetcode 922. 按奇偶排序數組 II(雙指針)

給定一個非負整數數組 A&#xff0c; A 中一半整數是奇數&#xff0c;一半整數是偶數。 對數組進行排序&#xff0c;以便當 A[i] 為奇數時&#xff0c;i 也是奇數&#xff1b;當 A[i] 為偶數時&#xff0c; i 也是偶數。 你可以返回任何滿足上述條件的數組作為答案。 示例&a…

機器學習 深度學習 ai_如何突破AI炒作成為機器學習工程師

機器學習 深度學習 aiI’m sure you’ve heard of the incredible artificial intelligence applications out there — from programs that can beat the world’s best Go players to self-driving cars.我敢肯定&#xff0c;您已經聽說過令人難以置信的人工智能應用程序-從可…

arcgis插值不覆蓋區劃圖_ArcGIS繪圖—空氣質量站點數據插值繪制等值線圖

作者&#xff1a;吳琳&#xff1b;陳天舒&#xff0c;山東大學環境科學&#xff08;大氣化學&#xff09;博士在讀數據&#xff08;Excel格式&#xff09;&#xff1a;多站點污染物數據&#xff08;國&#xff0c;省&#xff0c;市控點&#xff09;&#xff0c;站點經緯度信息繪…

數字校驗

1 function validNumber(fieldname,fielddesc){2 var value $.trim($("#key_"fieldname).val());3 var num /^([0-9.])$/;4 5 var flag num.test(value);6 if(!flag) {7 alert("【"fielddesc"】只能輸入數字");8 …

JavaScript覆蓋率統計實現

主要需求 1、 支持browser & nodejs 由于javascript既能夠在瀏覽器環境執行&#xff0c;也能夠在nodejs環境執行&#xff0c;因此須要能夠統計兩種環境下單元測試的覆蓋率情況。 2、 透明、無縫 用戶寫單元測試用例的時候&#xff0c;不須要為了支持覆蓋率統計多寫代碼&…

leetcode 328. 奇偶鏈表(雙指針)

給定一個單鏈表&#xff0c;把所有的奇數節點和偶數節點分別排在一起。請注意&#xff0c;這里的奇數節點和偶數節點指的是節點編號的奇偶性&#xff0c;而不是節點的值的奇偶性。 請嘗試使用原地算法完成。你的算法的空間復雜度應為 O(1)&#xff0c;時間復雜度應為 O(nodes)…

NSLog打印當前文件,當前函數,當前行數

NSLog(”%s, %s, %d”, __FILE__, __FUNCTION__, __LINE__); 轉載于:https://www.cnblogs.com/shenfei2031/archive/2011/08/06/2129636.html

單元格內容分列多行_姓名太多,放在一列打印時浪費紙張,可以分成多行多列打印...

在日常工作中&#xff0c;往往會碰到這種情況(如下圖)&#xff1a;只有一列數據&#xff0c;而且比較多&#xff0c;如果打印起來就浪費紙張&#xff0c;然后復制、粘貼把表格變成幾列&#xff0c;方便打印。今天小編和大家分享不用復制、粘貼&#xff0c;就能快速完成一列分成…

caesar加密_如何編寫Caesar密碼:基本加密簡介

caesar加密by Brendan Massey由布倫丹梅西(Brendan Massey) The Caesar Cipher is a famous implementation of early day encryption. It would take a sentence and reorganize it based on a key that is enacted upon the alphabet. Take, for example, a key of 3 and th…

Java中接口、抽象類與內部類學習

2019獨角獸企業重金招聘Python工程師標準>>> Java中接口、抽象類與內部類學習 接口與內部類為我們提供了一種將接口與實現分離的更加結構化的方法。 抽象類和抽象方法 抽象方法&#xff1a;僅有聲明而沒有方法體。 抽象類&#xff1a;包含一個或多個抽象方法的類&am…

leetcode 402. 移掉K位數字(貪心算法)

給定一個以字符串表示的非負整數 num&#xff0c;移除這個數中的 k 位數字&#xff0c;使得剩下的數字最小。 注意: num 的長度小于 10002 且 ≥ k。 num 不會包含任何前導零。 示例 1 : 輸入: num “1432219”, k 3 輸出: “1219” 解釋: 移除掉三個數字 4, 3, 和 2 形成…

javascript 自定義Map

遷移時間&#xff1a;2017年5月25日08:24:19 Author:Marydon 三、自定義Map數據格式 需特別注意的是&#xff1a; js中沒有像java中的Map數據格式&#xff0c;js自帶的map()方法用于&#xff1a;返回一個由原數組中的每個元素調用一個指定方法后的返回值組成的新數組。 map()使…

gif分解合成_如何通過分解和合成使復雜的問題更容易

gif分解合成Discover Functional JavaScript was named one of the best new Functional Programming books by BookAuthority!“發現功能JavaScript”被BookAuthority評為最佳新功能編程書籍之一 &#xff01; Our natural way of dealing with complexity is to break it in…

vs2005 新建項目一片空白

最近在研究 workflow fundation ,但是在安裝了他的extensions之后&#xff0c;發現VS2005 新建項目一片空白&#xff0c;除開workflow其他的項目模板全部丟失&#xff0c;新建項目對話框中空空如也。查閱資料后發現&#xff0c;可以通過 命令 devenv.exe /InstallVSTemplates 來…

docker導入鏡像 liunx_docker掃盲?面試連這都不會就等著掛吧

推薦閱讀&#xff1a;java喵&#xff1a;6大面試技能樹&#xff1a;JAVA基礎JVM算法數據庫計算機網絡操作系統?zhuanlan.zhihu.com一只Tom貓&#xff1a;都是“Redis惹的禍”&#xff0c;害我差點掛在美團三面&#xff0c;真是“虛驚一場”&#xff01;?zhuanlan.zhihu.com現…

crontab里shell腳本將top信息寫入文件

crontab里shell腳本將top信息寫入文件&#xff1a; 注&#xff1a; 1、top -n 1代表執行1次退出&#xff08;默認top是不退出的&#xff09;,-d 1代表每1秒執行1次 2、crontab里需加/bin/bash # crontab -e */5 * * * * /bin/bash /usr/local/bin/top.sh # vi top.sh #!/bin/ba…