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:
Java Program to Implement wheel Sieve to Generate Prime Numbers Between Given Range
Spring REST with a Zuul Proxy
Spring Boot - Thymeleaf
Java Program to Perform Right Rotation on a Binary Search Tree
Java Program to Implement Min Hash
Java Program to Implement Adjacency List
Java Program to Implement the Program Used in grep/egrep/fgrep
Java Program to Solve the Fractional Knapsack Problem
Java Program to Generate Random Numbers Using Middle Square Method
OAuth2 for a Spring REST API – Handle the Refresh Token in AngularJS
Sử dụng JDBC API thực thi câu lệnh truy vấn dữ liệu
Spring Boot Annotations
Finding Max/Min of a List or Collection
Java – InputStream to Reader
Java Program to Implement Skip List
Java Program to Implement Hash Tables Chaining with Binary Trees
Handling Errors in Spring WebFlux
Java Program to Solve any Linear Equation in One Variable
Java Program to Implement Knapsack Algorithm
Initialize a HashMap in Java
Giới thiệu Google Guice – Binding
Spring 5 Testing with @EnabledIf Annotation
Java Program to Implement Aho-Corasick Algorithm for String Matching
The Spring @Controller and @RestController Annotations
Sao chép các phần tử của một mảng sang mảng khác như thế nào?
Annotation trong Java 8
Java Program to Implement String Matching Using Vectors
Java Program to Implement RoleUnresolvedList API
Java Program to Perform Arithmetic Operations on Numbers of Size
Guava CharMatcher
Java Program to Solve a Matching Problem for a Given Specific Case
Spring 5 WebClient