This is a java program to search sequence using binary search. This is a simple extension of binary search algorithm to find an element.
Here is the source code of the Java Program to Implement a Binary Search Algorithm for a Specific Search Sequence. The Java program is successfully compiled and run on a Windows system. The program output is also shown below.
package com.sanfoundry.combinatorial;
import java.util.Random;
import java.util.Scanner;
public class BinarySearchSequence
{
public static void searchSequence(int[] array, int[] search)
{
int first, last, middle;
first = 0;
last = array.length - 1;
boolean flag = true;
for (int i = 0; i < search.length; i++)
{
middle = (first + last) / 2;
while (first <= last && flag == true)
{
if (array[middle] < search[i])
{
first = middle + 1;
}
else if (array[middle] == search[i])
{
System.out.println(search[i] + " found at location "
+ (middle + 1) + ".");
first = 0;
last = array.length - 1;
break;
}
else
{
last = middle - 1;
}
middle = (first + last) / 2;
}
if (first > last)
{
System.out
.println(search[i] + " is not present in the list.");
flag = false;
}
}
}
public static void main(String args[])
{
int c, n, search[], array[];
Scanner in = new Scanner(System.in);
System.out.println("Enter number of elements: ");
n = in.nextInt();
array = new int[n];
Random rand = new Random();
for (c = 0; c < n; c++)
{
array = rand.nextInt(100);
}
System.out.println("Elements: ");
for (int i = 0; i < array.length; i++)
{
System.out.print(array[i] + " ");
}
System.out.println("\nEnter length of sequence to find: ");
int m = in.nextInt();
search = new int[m];
System.out.println("Enter the sequence to find: ");
for (int i = 0; i < m; i++)
{
search[i] = in.nextInt();
}
searchSequence(array, search);
in.close();
}
}
Output:
$ javac BinarySearchSequence.java $ java BinarySearchSequence Enter number of elements: 10 Elements: 68 45 85 63 7 48 44 93 10 20 Enter length of sequence to find: 2 Enter the sequence to find: 7 48 7 found at location 5. 48 found at location 6. Enter number of elements: 10 Elements: 60 52 44 55 55 25 34 97 24 18 Enter length of sequence to find: 3 Enter the sequence to find: 2 3 4 2 is not present in the list. 3 is not present in the list. 4 is not present in the list.
Related posts:
A Guide to BitSet in Java
Guide To CompletableFuture
Spring Boot - Cloud Configuration Server
Spring MVC and the @ModelAttribute Annotation
Java Program to Implement Variable length array
Java Program to Perform Naive String Matching
Java Program to Compute the Volume of a Tetrahedron Using Determinants
Guide to DelayQueue
Java Program to Implement Graph Structured Stack
Java Program to Solve any Linear Equation in One Variable
Most commonly used String methods in Java
Spring Boot - Building RESTful Web Services
Mockito and JUnit 5 – Using ExtendWith
Bootstrapping Hibernate 5 with Spring
Java Program to Construct K-D Tree for 2 Dimensional Data
Annotation trong Java 8
Java Program to Show the Duality Transformation of Line and Point
Java Program to Generate All Possible Combinations of a Given List of Numbers
Introduction to the Java NIO2 File API
Java Program to Search Number Using Divide and Conquer with the Aid of Fibonacci Numbers
Java Program to Find Transpose of a Graph Matrix
How to Use if/else Logic in Java 8 Streams
Spring Cloud AWS – EC2
Working with Tree Model Nodes in Jackson
Vòng lặp for, while, do-while trong Java
Updating your Password
Guide to Java 8’s Collectors
Java Program to Find k Numbers Closest to Median of S, Where S is a Set of n Numbers
Apache Commons Collections MapUtils
OAuth2 Remember Me with Refresh Token
Serialize Only Fields that meet a Custom Criteria with Jackson
Java Program to Use Above Below Primitive to Test Whether Two Lines Intersect