日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

90. Leetcode 剑指 Offer 62. 圆圈中最后剩下的数字 (动态规划-基础题)

發布時間:2025/4/5 编程问答 14 豆豆
生活随笔 收集整理的這篇文章主要介紹了 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. 圆圈中最后剩下的数字 (动态规划-基础题)的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。