This is a Java Program to implement First fit Decreasing Bin Packing algorithm. The First Fit Decreasing (FFD) strategy, operates by first sorting the items to be inserted in decreasing order by their sizes, and then inserting each item into the first bin in the list with sufficient remaining space.
Here is the source code of the Java Program to Implement First Fit Decreasing for 1-D Objects and M Bins. The Java program is successfully compiled and run on a Windows system. The program output is also shown below.
//This is a java program to implement first fit decreasing for 1D objects using M bins
import java.util.Scanner;
public class First_Fit_Decreasing_Bin_Packing
{
public static void main(String args[])
{
System.out
.println("BIN - PACKING Algorithm 1D Objects(First Fit Decreasing)");
System.out.println("Enter the number of items in Set: ");
Scanner sc = new Scanner(System.in);
int n = sc.nextInt();
System.out.println("Enter " + n + " items:");
int[] a = new int[n];
for (int i = 0; i < n; i++)
a[i] = sc.nextInt();
System.out.println("Enter the bin size: ");
int size = sc.nextInt();
int[] sequence = sort(a);
binPacking(sequence, size, n);
sc.close();
}
public static void binPacking(int[] a, int size, int n)
{
int binCount = 0;
int[] binValues = new int[n];
for (int i = 0; i < binValues.length; i++)
binValues[i] = size;
for (int i = 0; i < n; i++)
for (int j = 0; j < binValues.length; j++)
{
if (binValues[j] - a[i] >= 0)
{
binValues[j] -= a[i];
break;
}
}
for (int i = 0; i < binValues.length; i++)
if (binValues[i] != size)
binCount++;
System.out
.println("Number of bins required using first fit decreasing algorithm is:"
+ binCount);
}
static int[] sort(int[] sequence)
{
// Bubble Sort descending order
for (int i = 0; i < sequence.length; i++)
for (int j = 0; j < sequence.length - 1; j++)
if (sequence[j] < sequence[j + 1])
{
sequence[j] = sequence[j] + sequence[j + 1];
sequence[j + 1] = sequence[j] - sequence[j + 1];
sequence[j] = sequence[j] - sequence[j + 1];
}
return sequence;
}
}
Output:
$ javac First_Fit_Decreasing_Bin_Packing.java $ java First_Fit_Decreasing_Bin_Packing BIN - PACKING Algorithm for 1D Objects(First Fit Decreasing) Enter the number of items in Set: 9 Enter 9 items: 4 1 2 5 3 2 3 6 3 Enter the bin size: 6 Number of bins required using first fit decreasing algorithm is:5
Related posts:
Java Program to Perform Sorting Using B-Tree
Hướng dẫn sử dụng Java Annotation
Merging Two Maps with Java 8
Check if a String is a Palindrome in Java
Read an Outlook MSG file
New Features in Java 9
Spring Boot - Web Socket
Spring Boot - File Handling
Java Program to Implement JobStateReasons API
Java Program to Perform Partial Key Search in a K-D Tree
Reactive WebSockets with Spring 5
Java program to Implement Tree Set
Java Program to Perform Addition Operation Using Bitwise Operators
Lớp TreeMap trong Java
Create Java Applet to Simulate Any Sorting Technique
Java Program to Generate Random Hexadecimal Byte
Spring Cloud AWS – RDS
A Guide to JUnit 5
Multipart Upload with HttpClient 4
Hướng dẫn Java Design Pattern – Proxy
Java Program to Check whether Directed Graph is Connected using DFS
Guide to CountDownLatch in Java
Java Program to Implement Quick Sort with Given Complexity Constraint
Java Streams vs Vavr Streams
Testing in Spring Boot
Java – Byte Array to Reader
Array to String Conversions
Spring Boot - Creating Docker Image
Java Program to Check if a Given Set of Three Points Lie on a Single Line or Not
Apache Commons Collections SetUtils
Spring Boot - Exception Handling
Introduction to Spring Cloud Netflix – Eureka