Skip to content

Commit

Permalink
Added W05 materials
Browse files Browse the repository at this point in the history
  • Loading branch information
IvanSol committed Nov 5, 2024
1 parent f275944 commit 5889a1d
Show file tree
Hide file tree
Showing 2 changed files with 49 additions and 2 deletions.
4 changes: 2 additions & 2 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -29,7 +29,7 @@
[Slides_W02]: ../master/week02_binary_search/MSAI.2024.Algo.W02.slides.pdf
[Slides_W03]: ../master/week03_basic_data_structures/MSAI.2024.Algo.W03.slides.pdf
[Slides_W04]: ../master/week04_dynamic_programming/MSAI.2024.Algo.W04.slides.pdf
[Slides_W05]: ../master/week05_knapsack/MSAI.2024.Algo.W05.slides.pdf
[Slides_W05]: ../msai22_state/week05_knapsack/MSAI.2022.Algo.W05.slides.pdf
[Slides_W06]: ../master/week06_kmp_heap/MSAI.2024.Algo.W06.slides.pdf
[Slides_W07]: ../master/week07_dfs_bfs/MSAI.2024.Algo.W07.slides.pdf
[Slides_W08]: ../master/week08_shortest_paths/MSAI.2024.Algo.W08.slides.pdf
Expand All @@ -43,8 +43,8 @@
| 02 | Binary search | [Slides][Slides_W02] | [Test][WarmUp_test_W02] | [Contest][ContestID_W02] | 21.10.2024 19:00 UTC+3 |
| 03 | Basic Data sturctures | [Slides][Slides_W03] | [Test][WarmUp_test_W03] | [Contest][ContestID_W03] | 28.10.2024 19:00 UTC+3 |
| 04 | Dynamic programming | [Slides][Slides_W04] | [Test][WarmUp_test_W04] | [Contest][ContestID_W04] | 04.11.2024 19:00 UTC+3 |
| 05 | Knapsack problem | [Slides][Slides_W05] | [Test][WarmUp_test_W05] | [Contest][ContestID_W05] | 11.11.2024 19:00 UTC+3 |
<!---
| 05 | Knapsack problem | [Slides][Slides_W05] | [Test][WarmUp_test_W05] | [Contest][ContestID_W05] | ??.11.2024 19:00 UTC+3 |
| 06 | KMP & Heap | [Slides][Slides_W06] | [Test][WarmUp_test_W06] | [Contest][ContestID_W06] | ??.11.2024 19:00 UTC+3 |
| 07 | DFS & BFS | [Slides][Slides_W07] | [Test][WarmUp_test_W07] | [Contest][ContestID_W07] | ??.12.2024 19:00 UTC+3 |
| 08 | Shortest paths | [Slides][Slides_W08] | [Test][WarmUp_test_W08] | [Contest][ContestID_W08] | ??.12.2024 19:00 UTC+3 |
Expand Down
47 changes: 47 additions & 0 deletions week05_knapsack/knapsack.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,47 @@
W = 8
N = 4
wi = [3, 3, 5, 6]
ci = [3, 5, 10, 14]

d = [[0] * (W + 1) for i in range(N + 1)]
for i in range(1, N + 1):
for w in range(1, W + 1):
if wi[i-1] > w:
d[i][w] = d[i-1][w]
else:
d[i][w] = max(d[i-1][w], d[i-1][w-wi[i-1]]+ci[i-1])

print('\n'.join([' '.join(map(str, d[i])) for i in range(N + 1)]))


# Python3 program to find maximum
# achievable value with a knapsack
# of weight W and multiple instances allowed.

# Returns the maximum value
# with knapsack of W capacity
def unboundedKnapsack(W, n, val, wt):
# dp[i] is going to store maximum
# value with knapsack capacity i.
dp = [0 for i in range(W + 1)]

ans = 0

# Fill dp[] using above recursive formula
for i in range(W + 1):
for j in range(n):
if (wt[j] <= i):
dp[i] = max(dp[i], dp[i - wt[j]] + val[j])
print(dp)
return dp[W]


# Driver program
W = 5
val = [10]
wt = [2]
n = len(val)

print(unboundedKnapsack(W, n, val, wt))

# This code is contributed by Anant Agarwal.

0 comments on commit 5889a1d

Please sign in to comment.