回答編集履歴
1
コメントに対する追記
test
CHANGED
@@ -21,3 +21,27 @@
|
|
21
21
|
|
22
22
|
|
23
23
|
ちなみにこの問題は部分和問題の一種のようなので、おそらくこれ以上に効率のいいアルゴリズムはないんじゃないかと思います。本当にこの問題設定であってますか?
|
24
|
+
|
25
|
+
|
26
|
+
|
27
|
+
---
|
28
|
+
|
29
|
+
当初の問題設定だと、ガソリンを補給する量が多すぎても少なすぎてもダメなので、ガソリンをどれだけ補給したか正確に記録しておく必要があります。
|
30
|
+
|
31
|
+
> DP[i][g + Gi] = DP[i - 1][g] or DP[i - 1][g + Gi](ただし g >= Pi )
|
32
|
+
|
33
|
+
この部分についてですが、
|
34
|
+
|
35
|
+
「i番目のガソリンスタンドにたどり着くには、i-1番目までのガソリンスタンドでもっている保有量と等しいかそれ以上(但し保有量の方がガソリンスタンドで補給する量と等しいかそれ以上)」
|
36
|
+
|
37
|
+
という意味でしょうか。
|
38
|
+
|
39
|
+
|
40
|
+
|
41
|
+
なのでDP[i][g + Gi]はぴったりg + Giのガソリンを補給することが可能かどうかを表しています。
|
42
|
+
|
43
|
+
右辺を分解すると、DP[i - 1][g + Gi]がi番目のガソリンスタンドを使わない場合で、DP[i - 1][g]がi番目のガソリンスタンドを使わない場合です。(この点最初の式は不正確で、実際にはg + Gi >= Pi and g < Pi の時にはDP[i][g] = DP[i - 1][g]が成り立ちます)
|
44
|
+
|
45
|
+
|
46
|
+
|
47
|
+
とはいえ最小回数を求めるだけならこの辺は全く関係なく、プライオリティキューをつかって貪欲に補給していくだけで計算可能です。詳しくはPOJ 2431という条件が違うだけの問題が有名なので、その解説を参考にしてください。
|