This is a Java Program to Implement Knapsack Algorithm. This algorithm is used to solve knapsack problem : Given a set of items, each with a mass and a value, determine the number of each item to include in a collection so that the total weight is less than or equal to a given limit and the total value is as large as possible.
Here is the source code of the Java Program to Implement Knapsack Algorithm. The Java program is successfully compiled and run on a Windows system. The program output is also shown below.
/**
** Java Program to Implement Knapsack Algorithm
**/
import java.util.Scanner;
/** Class Knapsack **/
public class Knapsack
{
public void solve(int[] wt, int[] val, int W, int N)
{
int NEGATIVE_INFINITY = Integer.MIN_VALUE;
int[][] m = new int[N + 1][W + 1];
int[][] sol = new int[N + 1][W + 1];
for (int i = 1; i <= N; i++)
{
for (int j = 0; j <= W; j++)
{
int m1 = m[i - 1][j];
int m2 = NEGATIVE_INFINITY;
if (j >= wt[i])
m2 = m[i - 1][j - wt[i]] + val[i];
/** select max of m1, m2 **/
m[i][j] = Math.max(m1, m2);
sol[i][j] = m2 > m1 ? 1 : 0;
}
}
/** make list of what all items to finally select **/
int[] selected = new int[N + 1];
for (int n = N, w = W; n > 0; n--)
{
if (sol[n][w] != 0)
{
selected[n] = 1;
w = w - wt[n];
}
else
selected[n] = 0;
}
/** Print finally selected items **/
System.out.println("\nItems selected : ");
for (int i = 1; i < N + 1; i++)
if (selected[i] == 1)
System.out.print(i +" ");
System.out.println();
}
/** Main function **/
public static void main (String[] args)
{
Scanner scan = new Scanner(System.in);
System.out.println("Knapsack Algorithm Test\n");
/** Make an object of Knapsack class **/
Knapsack ks = new Knapsack();
System.out.println("Enter number of elements ");
int n = scan.nextInt();
int[] wt = new int[n + 1];
int[] val = new int[n + 1];
System.out.println("\nEnter weight for "+ n +" elements");
for (int i = 1; i <= n; i++)
wt[i] = scan.nextInt();
System.out.println("\nEnter value for "+ n +" elements");
for (int i = 1; i <= n; i++)
val[i] = scan.nextInt();
System.out.println("\nEnter knapsack weight ");
int W = scan.nextInt();
ks.solve(wt, val, W, n);
}
}
Output:
Knapsack Algorithm Test Enter number of elements 5 Enter weight for 5 elements 50 10 20 40 30 Enter value for 5 elements 300 60 90 100 240 Enter knapsack weight 60 Items selected : 2 3 5
Related posts:
Java Program to Implement Booth Algorithm
Introduction to PCollections
Java Program to Implement Bloom Filter
Ignore Null Fields with Jackson
Hướng dẫn Java Design Pattern – Command
Compact Strings in Java 9
Immutable Objects in Java
JUnit 5 for Kotlin Developers
Java Program to Implement Red Black Tree
Spring Security Basic Authentication
Tính đa hình (Polymorphism) trong Java
Tạo chương trình Java đầu tiên sử dụng Eclipse
Deploy a Spring Boot WAR into a Tomcat Server
Circular Dependencies in Spring
Đồng bộ hóa các luồng trong Java
Hướng dẫn Java Design Pattern – Flyweight
Spring MVC Content Negotiation
Java Program to Implement Bellman-Ford Algorithm
Jackson Ignore Properties on Marshalling
Java Program to Implement Quick Hull Algorithm to Find Convex Hull
Introduction to Spring Cloud Rest Client with Netflix Ribbon
Java Program to Find the Minimum value of Binary Search Tree
Examine the internal DNS cache
Java IO vs NIO
Java Program to Implement the Bin Packing Algorithm
Java Program to Implement Stack
@Before vs @BeforeClass vs @BeforeEach vs @BeforeAll
Intro to Inversion of Control and Dependency Injection with Spring
HttpClient 4 – Follow Redirects for POST
String Joiner trong Java 8
Handle EML file with JavaMail
Quick Guide to Spring MVC with Velocity