This is java program to implement Knapsack problem using Dynamic programming.Given weights and values of n items, put these items in a knapsack of capacity W to get the maximum total value in the knapsack. Consider all subsets of items and calculate the total weight and value of all subsets. Consider the only subsets whose total weight is smaller than W. From all such subsets, pick the maximum value subset.
Here is the source code of the Java Program to Solve Knapsack Problem Using Dynamic Programming. The Java program is successfully compiled and run on a Windows system. The program output is also shown below.
//This is the java program to implement the knapsack problem using Dynamic Programming
import java.util.Scanner;
public class Knapsack_DP
{
static int max(int a, int b)
{
return (a > b)? a : b;
}
static int knapSack(int W, int wt[], int val[], int n)
{
int i, w;
int [][]K = new int[n+1][W+1];
// Build table K[][] in bottom up manner
for (i = 0; i <= n; i++)
{
for (w = 0; w <= W; w++)
{
if (i==0 || w==0)
K[i][w] = 0;
else if (wt[i-1] <= w)
K[i][w] = max(val[i-1] + K[i-1][w-wt[i-1]], K[i-1][w]);
else
K[i][w] = K[i-1][w];
}
}
return K[n][W];
}
public static void main(String args[])
{
Scanner sc = new Scanner(System.in);
System.out.println("Enter the number of items: ");
int n = sc.nextInt();
System.out.println("Enter the items weights: ");
int []wt = new int[n];
for(int i=0; i<n; i++)
wt[i] = sc.nextInt();
System.out.println("Enter the items values: ");
int []val = new int[n];
for(int i=0; i<n; i++)
val[i] = sc.nextInt();
System.out.println("Enter the maximum capacity: ");
int W = sc.nextInt();
System.out.println("The maximum value that can be put in a knapsack of capacity W is: " + knapSack(W, wt, val, n));
sc.close();
}
}
Output:
$ javac Knapsack_DP.java $ java Knapsack_DP Enter the number of items: 5 Enter the items weights: 01 56 42 78 12 Enter the items values: 50 30 20 10 50 Enter the maximum capacity: 150 The maximum value that can be put in a knapsack of capacity W is: 150
Related posts:
Spring RestTemplate Error Handling
Create a Custom Auto-Configuration with Spring Boot
Java Program to Solve a Matching Problem for a Given Specific Case
Spring Boot - Cloud Configuration Client
Transactions with Spring and JPA
Java Program to Perform Partial Key Search in a K-D Tree
Java Program to Generate Random Partition out of a Given Set of Numbers or Characters
Tips for dealing with HTTP-related problems
Java Program to Implement Patricia Trie
Spring Boot - Internationalization
Java Program to Implement Shunting Yard Algorithm
Java Program to Perform Postorder Non-Recursive Traversal of a Given Binary Tree
Lớp Properties trong java
Sao chép các phần tử của một mảng sang mảng khác như thế nào?
Practical Java Examples of the Big O Notation
Spring WebClient Requests with Parameters
Spring Boot - Build Systems
Implementing a Runnable vs Extending a Thread
Java Program to Implement Disjoint Sets
Custom HTTP Header with the HttpClient
MyBatis with Spring
Deque và ArrayDeque trong Java
Spring Boot - Creating Docker Image
Ép kiểu trong Java (Type casting)
Remove All Occurrences of a Specific Value from a List
Spring MVC Setup with Kotlin
Using Optional with Jackson
Guide to the Fork/Join Framework in Java
Java Program to Implement ConcurrentHashMap API
Java Program to Implement Ternary Search Tree
Java Program to Check Whether it is Weakly Connected or Strongly Connected for a Directed Graph
Spring AMQP in Reactive Applications