90. Leetcode 剑指 Offer 62. 圆圈中最后剩下的数字 (动态规划-基础题)
生活随笔
收集整理的這篇文章主要介紹了
90. Leetcode 剑指 Offer 62. 圆圈中最后剩下的数字 (动态规划-基础题)
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
步驟一、確定狀態:
確定dp數組及含義 dp[i]表示的是i個數里面循環刪除m個數剩下的數
步驟二、推斷狀態方程:
首先假設f(n,m)表示從n個數字0....n?1中每次刪除第 m個數字之后剩下的數字。 那么在這n個數字中, 第 一個被刪除的是 (m?1)%n,假設這個數用k表示,那 么刪除k剩下的n?1個數字0 , 1 , . . k ? 1 , k +1 , . . . n ? 1 ,并且下一次要從k+1開始計數。那么 我們假設再換成上面那種方式,把k+1映射成0,k+2 映射成1,...那這樣這個問題就和上面那個一樣了,這 個新問題就變成了從n?1個數字0...n?2中每次刪除第 m個數字之后剩下的數字,記這個為f ′ (n?1,m)。注 意這個f ′ 和前面f不是一個函數了,經過了映射。顯 然,最初序列最后剩下的數字一定是刪除一個數字之 后序列最后剩下的數字,即f(n?1,m)=f ′ (n?1,m)
?
?
步驟三、規定初始條件:
初始條件: dp[1]=0
步驟四、計算順序:
i從2到n遍歷
class Solution:def lastRemaining(self, n: int, m: int) -> int:dp = [0] * (n+1)dp[1] = 0for i in range(2, n+1):dp[i] = (m+dp[i-1])%ireturn dp[-1]?
《新程序員》:云原生和全面數字化實踐50位技術專家共同創作,文字、視頻、音頻交互閱讀總結
以上是生活随笔為你收集整理的90. Leetcode 剑指 Offer 62. 圆圈中最后剩下的数字 (动态规划-基础题)的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 89. Leetcode 96. 不同的
- 下一篇: 91. Leetcode 62. 不同路