BAEL-3349, Add brackets and make the class public
This commit is contained in:
@@ -1,19 +1,22 @@
|
|||||||
package com.baeldung.algorithms.knapsack;
|
package com.baeldung.algorithms.knapsack;
|
||||||
|
|
||||||
class Knapsack {
|
public class Knapsack {
|
||||||
|
|
||||||
public int knapsackRec(int[] w, int[] v, int n, int W) {
|
public int knapsackRec(int[] w, int[] v, int n, int W) {
|
||||||
if (n <= 0)
|
if (n <= 0) {
|
||||||
return 0;
|
return 0;
|
||||||
else if (w[n - 1] > W)
|
} else if (w[n - 1] > W) {
|
||||||
return knapsackRec(w, v, n - 1, W);
|
return knapsackRec(w, v, n - 1, W);
|
||||||
else
|
} else {
|
||||||
return Math.max(knapsackRec(w, v, n - 1, W), v[n - 1] + knapsackRec(w, v, n - 1, W - w[n - 1]));
|
return Math.max(knapsackRec(w, v, n - 1, W), v[n - 1] + knapsackRec(w, v, n - 1, W - w[n - 1]));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public int knapsackDP(int[] w, int[] v, int n, int W) {
|
public int knapsackDP(int[] w, int[] v, int n, int W) {
|
||||||
if (n <= 0 || W <= 0)
|
if (n <= 0 || W <= 0) {
|
||||||
return 0;
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
int[][] m = new int[n + 1][W + 1];
|
int[][] m = new int[n + 1][W + 1];
|
||||||
for (int j = 0; j <= W; j++) {
|
for (int j = 0; j <= W; j++) {
|
||||||
m[0][j] = 0;
|
m[0][j] = 0;
|
||||||
@@ -21,10 +24,11 @@ class Knapsack {
|
|||||||
|
|
||||||
for (int i = 1; i <= n; i++) {
|
for (int i = 1; i <= n; i++) {
|
||||||
for (int j = 1; j <= W; j++) {
|
for (int j = 1; j <= W; j++) {
|
||||||
if (w[i - 1] > j)
|
if (w[i - 1] > j) {
|
||||||
m[i][j] = m[i - 1][j];
|
m[i][j] = m[i - 1][j];
|
||||||
else
|
} else {
|
||||||
m[i][j] = Math.max(m[i - 1][j], m[i - 1][j - w[i - 1]] + v[i - 1]);
|
m[i][j] = Math.max(m[i - 1][j], m[i - 1][j - w[i - 1]] + v[i - 1]);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return m[n][W];
|
return m[n][W];
|
||||||
|
|||||||
Reference in New Issue
Block a user