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:
Debug a JavaMail Program
Java Program to Generate Random Hexadecimal Byte
Java Program to Perform Searching in a 2-Dimension K-D Tree
Java Program to Generate a Random UnDirected Graph for a Given Number of Edges
Java Program to Implement Caesar Cypher
Java Collections Interview Questions
Annotation trong Java 8
Java Program to Implement Radix Sort
A Custom Media Type for a Spring REST API
Java Program to Implement AA Tree
Java Program to Find the Longest Subsequence Common to All Sequences in a Set of Sequences
Java Optional as Return Type
XML Serialization and Deserialization with Jackson
SOAP Web service: Authentication trong JAX-WS
Returning Image/Media Data with Spring MVC
Java Program to Implement RoleList API
Spring Autowiring of Generic Types
Java Program to Implement Leftist Heap
Easy Ways to Write a Java InputStream to an OutputStream
Java Program to Implement CopyOnWriteArraySet API
Java Program to Implement Stack
Using Spring ResponseEntity to Manipulate the HTTP Response
Java Program to Implement Sorting of Less than 100 Numbers in O(n) Complexity
Java Program to Implement Fermat Primality Test Algorithm
Java Program to Implement Fermat Factorization Algorithm
Converting String to Stream of chars
Giới thiệu Design Patterns
Guide to Java Instrumentation
Java Program to Perform integer Partition for a Specific Case
Java Program to Implement Shell Sort
Java Program to do a Breadth First Search/Traversal on a graph non-recursively
Java – Write an InputStream to a File