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:
Split a String in Java
Java Streams vs Vavr Streams
Introduction to Using FreeMarker in Spring MVC
How to Get the Last Element of a Stream in Java?
Java Program to Delete a Particular Node in a Tree Without Using Recursion
Spring Boot - Building RESTful Web Services
Java Program to Implement Park-Miller Random Number Generation Algorithm
Spring Boot - Web Socket
Java 8 Stream findFirst() vs. findAny()
Spring Boot - Quick Start
Java Program to Implement Branch and Bound Method to Perform a Combinatorial Search
Introduction to Spring Data MongoDB
Java Program to Perform Insertion in a BST
REST Web service: Upload và Download file với Jersey 2.x
Thực thi nhiều tác vụ cùng lúc như thế nào trong Java?
Java – Reader to InputStream
Recommended Package Structure of a Spring Boot Project
The HttpMediaTypeNotAcceptableException in Spring MVC
Handling Errors in Spring WebFlux
Java Program to Implement Heap
Build a REST API with Spring and Java Config
REST Web service: Basic Authentication trong Jersey 2.x
Spring Boot - Actuator
Hướng dẫn Java Design Pattern – Object Pool
Java Program to Perform Right Rotation on a Binary Search Tree
How to Add a Single Element to a Stream
Java InputStream to String
Spring RestTemplate Error Handling
Extra Login Fields with Spring Security
Java Program to Describe the Representation of Graph using Adjacency List
DistinctBy in the Java Stream API
Java Program to Generate All Possible Combinations Out of a, b, c, d, e