This is a java program to perform uniform binary search technique. It uses a lookup table to update a single array index, rather than taking the midpoint of an upper and a lower bound on each iteration; therefore, it is optimized for architectures (such as Knuth’s MIX) on which a table look-up is generally faster than an addition and a shift, and many searches will be performed on the same array, or on several arrays of the same length.
Here is the source code of the Java Program to Perform Uniform Binary Search. 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 perform uniform binary search. import java.util.Random; import java.util.Scanner; public class Uniform_Binary_Search { static int N = 10; static int[] sequence = new int[N]; static int[] delta = new int[42]; public static void sort() { int i, j, temp; for (i = 1; i < N; i++) { j = i; temp = sequence[i]; while (j > 0 && temp < sequence[j - 1]) { sequence[j] = sequence[j - 1]; j = j - 1; } sequence[j] = temp; } } public static void make_delta(int N) { System.out.println(); int power = 1; int i = 0; do { int half = power; power <<= 1; delta[i] = (N + half) / power; } while (delta[i++] != 0); } public static int unisearch(int key) { int i = delta[0] - 1; /* midpoint of array */ int d = 0; while (true) { if (key == sequence[i]) return i; else if (delta[d] == 0) return -1; else { if (key < sequence[i]) i -= delta[++d]; else i += delta[++d]; } } } public static void main(String args[]) { Random random = new Random(); for (int i = 0; i < N; i++) sequence[i] = Math.abs(random.nextInt(100)); System.out.println("The sequence is :"); sort(); for (int i = 0; i < N; i++) System.out.print(sequence[i] + " "); //sort(); make_delta(N); System.out.println("Enter the element to be searched: "); Scanner sc = new Scanner(System.in); int key = sc.nextInt(); int p = unisearch(key); if (p > 0) System.out.println("Element found at position " + p); else System.out.println("Element doesn't exist"); sc.close(); } }
Output:
$ javac Uniform_Binary_Search.java $ java Uniform_Binary_Search The sequence is : 12 13 20 24 27 32 63 64 74 82 Enter the element to be searched: 24 Element found at position 3 The sequence is : 0 30 31 32 37 48 51 58 78 87 Enter the element to be searched: 98 Element doesn't exist
Related posts:
Immutable Objects in Java
Working With Maps Using Streams
Inject Parameters into JUnit Jupiter Unit Tests
Simple Single Sign-On with Spring Security OAuth2
Java Program to Implement Interval Tree
Java Program to Generate a Random Subset by Coin Flipping
String Operations with Java Streams
Hướng dẫn Java Design Pattern – Prototype
Entity To DTO Conversion for a Spring REST API
Java Program to Implement a Binary Search Algorithm for a Specific Search Sequence
Java Program to Implement HashSet API
Java Program to Implement Jarvis Algorithm
How to Set TLS Version in Apache HttpClient
Giới thiệu Json Web Token (JWT)
Java Program to Check Whether an Undirected Graph Contains a Eulerian Path
Using a Mutex Object in Java
Functional Interface trong Java 8
Query Entities by Dates and Times with Spring Data JPA
Generic Constructors in Java
Convert String to Byte Array and Reverse in Java
Từ khóa this và super trong Java
HttpAsyncClient Tutorial
HashSet trong Java hoạt động như thế nào?
Java Program to Implement Sparse Array
Setting a Request Timeout for a Spring REST API
Spring Web Annotations
Java – String to Reader
Guide to the Java TransferQueue
Java Program to Implement Hash Tables Chaining with List Heads
Returning Custom Status Codes from Spring Controllers
Java Program to Find Shortest Path Between All Vertices Using Floyd-Warshall’s Algorithm
Stack Memory and Heap Space in Java