This is java program to implement 0/1 Knapsack problem. The knapsack problem or rucksack problem is a problem in combinatorial optimization: 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. It derives its name from the problem faced by someone who is constrained by a fixed-size knapsack and must fill it with the most valuable items.
Here is the source code of the Java Program to Solve the 0-1 Knapsack Problem. The Java program is successfully compiled and run on a Windows system. The program output is also shown below.
//This is a sample program to implement a 0/1 knapsack algorithm
import java.util.Scanner;
public class Zero_One_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];
m[i][j] = Math.max(m1, m2);
sol[i][j] = m2 > m1 ? 1 : 0;
}
}
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;
}
System.out.print("\nItems with weight ");
for (int i = 1; i < N + 1; i++)
if (selected[i] == 1)
System.out.print(val[i] +" ");
System.out.println("are selected by knapsack algorithm.");
}
public static void main (String[] args)
{
Scanner scan = new Scanner(System.in);
Zero_One_Knapsack ks = new Zero_One_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("Enter weight for "+ n +" elements");
for (int i = 1; i <= n; i++)
wt[i] = scan.nextInt();
System.out.println("Enter value for "+ n +" elements");
for (int i = 1; i <= n; i++)
val[i] = scan.nextInt();
System.out.println("Enter knapsack weight ");
int W = scan.nextInt();
ks.solve(wt, val, W, n);
scan.close();
}
}
Output:
$ javac Zero_One_Knapsack.java $ java Zero_One_Knapsack Enter number of elements 5 Enter weight for 5 elements 01 56 42 78 12 Enter value for 5 elements 50 30 20 10 50 Enter knapsack weight 150 Items with weight 50 30 20 50 are selected by knapsack algorithm.
Related posts:
Find the Registered Spring Security Filters
Java Program to Use rand and srand Functions
Java Program to Implement Hash Tables with Linear Probing
Sử dụng CountDownLatch trong Java
Injecting Prototype Beans into a Singleton Instance in Spring
Java Program for Topological Sorting in Graphs
Java Scanner hasNext() vs. hasNextLine()
A Guide To UDP In Java
Guide to the Volatile Keyword in Java
Send an email using the SMTP protocol
Java Program to Perform Naive String Matching
Java Program to Generate N Number of Passwords of Length M Each
Câu lệnh điều khiển vòng lặp trong Java (break, continue)
Java Program to Check Whether a Given Point is in a Given Polygon
Creating a Generic Array in Java
Java Program to Implement Cartesian Tree
Java Program to Find the Median of two Sorted Arrays using Binary Search Approach
Hướng dẫn sử dụng Lớp FilePermission trong java
How to Return 404 with Spring WebFlux
HttpClient 4 – Send Custom Cookie
HttpClient Basic Authentication
ExecutorService – Waiting for Threads to Finish
Java Program to Implement Selection Sort
An Introduction to ThreadLocal in Java
Java Program to Implement Quick Sort with Given Complexity Constraint
Java Program to Implement Trie
Java Program to Implement the Alexander Bogomolny’s UnOrdered Permutation Algorithm for Elements Fro...
Spring Boot Application as a Service
Anonymous Classes in Java
Java Program to Implement Sieve Of Eratosthenes
Java Program to Implement the String Search Algorithm for Short Text Sizes
Properties with Spring and Spring Boot