現状
競技プログラミングを通して、アルゴリズムとコーディングについて勉強中です。
動的計画法の典型問題にナップサック問題(厳密に違いを分ける場合もあるらしい)について、いくつかのホームページを見て勉強しました。
動的計画法(ナップサック問題)
理解した内容をもとに、競技プログラミングの例題(Knapsack 1)に取り組んでみたのですが、回答が合わないようです。
以下は、私の書いたコードです。
python
1n,w=map(int,input().split()) 2goods=[list(map(int,input().split())) for _ in range(n)] 3DP=[[-1]*(w+1)]*(n+1) 4for i in list(range(n))[::-1]: 5 wi,vi=goods[i][0],goods[i][1] 6 for j in range(w+1): 7 if j<wi: 8 DP[i][j]=DP[i+1][j] 9 else: 10 DP[i][j]=max(DP[i+1][j],DP[i+1][j-wi]+vi) 11print(DP[0][w])
やったこと・教えてもらいたいこと
再帰関数を用いて、別の書き方を試してみましたが答えが合いませんでした。
浅い理解、あるいはどこか本質的に間違った理解をしていることが原因だと思います。
私の書いたコードの問題点や、改善点などを教えていただけないでしょうか?
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
退会済みユーザー
2020/02/05 09:26