網站首頁 編程語言 正文
背包問題
現在要往一個可以裝4個單位重量的背包里怎么裝價值最高:A重量1個單位,價值15;B重量3個單位,價值20;C重量4個重量,價值30
使用動態規劃填充空格
class SolutionBag:
def valuableBag(self,optionalList,sizeBig):
#創建網格
grid = [[0 for i in range(sizeBig+1)] for j in range(len(optionalList)+1)]
#從行列序號1開始計數
column = 1
for v in optionalList.values():
optionalWeight,optionalPrice = v
for row in range(sizeBig):
if optionalWeight > row+1:
grid[column][row+1] = grid[column-1][row+1]
else:
grid[column][row+1] = max(grid[column-1][row+1],optionalPrice+grid[column-1][row+1-optionalWeight])
column += 1
return grid#SolutionBag().valuableBag({"A":(1,15),"B":(3,20),"C":(4,30)},4)
最長公共子串
在動態規劃中,你要將某個指標最大化。在這個例子中,你要找出兩個單詞的最長公共子串。fish和fosh都包含的最長子串是什么呢
如何將這個問題劃分為子問題呢?你可能需要比較子串:不是比較hish和fish,而是先比較his和fis
我們網格填充的方法來實現
#偽代碼
#字母相同則左上方+1
if word1[i] == word2[j] :
cell[i][j] = cell[i-1][j-1] +1
else:
cell[i][j] = max(cell[i][j-1],cell[i-1][j])
python實現網格
class SolutionLengthS:
def longestLength(self,str1,str2):
grid = [[0 for j in range(len(str2)+1)] for i in range(len(str1)+1)]
for i in range(len(str2)):
for j in range(len(str1)):
if str1[j] == str2[i] :
grid[i+1][j+1] = grid[i][j] + 1
else:
grid[i+1][j+1] = max(grid[i+1][j],grid[i][j+1])
return grid
原文鏈接:https://www.cnblogs.com/yetangjian/p/16268741.html
相關推薦
- 2022-09-13 C語言實現統計一行字符串的單詞個數_C 語言
- 2022-08-07 Go?Grpc?Gateway兼容HTTP協議文檔自動生成網關_Golang
- 2022-06-28 ADO.NET防SQL注入與使用參數增刪改查_實用技巧
- 2022-11-02 Pytorch中DataLoader的使用方法詳解_python
- 2023-11-14 k8s安裝部署metrics-server;監測集群狀況
- 2022-02-28 獲取元素的寬度,高度
- 2023-01-20 基于?Dubbo?Admin?動態調整服務超時時間的操作步驟_其它綜合
- 2022-04-25 ASP.NET?Core中Razor頁面的Handlers處理方法詳解_基礎應用
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支