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.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 | //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:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 | $ 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:
Spring Boot - Service Components
How to Round a Number to N Decimal Places in Java
Java Program to Check if a Point d lies Inside or Outside a Circle Defined by Points a, b, c in a Pl...
So sánh ArrayList và LinkedList trong Java
Truyền giá trị và tham chiếu trong java
Java Program to Check if a Given Graph Contain Hamiltonian Cycle or Not
Java Program to Implement Word Wrap Problem
New Features in Java 8
Java Program to Implement the Checksum Method for Small String Messages and Detect
Anonymous Classes in Java
Create a Custom Exception in Java
Introduction to Spring Data JPA
Java Program to Check Whether Graph is DAG
ArrayList trong java
Java Program to Implement the linear congruential generator for Pseudo Random Number Generation
Concatenating Strings In Java
Java Program to Implement Bresenham Line Algorithm
Receive email using IMAP
Spring Boot - Admin Server
Java Program to Implement Interval Tree
Java TreeMap vs HashMap
Spring Boot - Exception Handling
Java Program to Describe the Representation of Graph using Incidence Matrix
Exploring the New Spring Cloud Gateway
Split a String in Java
Hướng dẫn Java Design Pattern – Factory Method
Adding Shutdown Hooks for JVM Applications
Primitive Type Streams in Java 8
JWT – Token-based Authentication trong Jersey 2.x
Spring Cloud AWS – RDS
Handling URL Encoded Form Data in Spring REST
Java 8 – Powerful Comparison with Lambdas