Java Program to Implement a Binary Search Algorithm for a Specific Search Sequence

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:

Spring Boot - Twilio
Java Program to Implement Sorted Circularly Singly Linked List
JWT – Token-based Authentication trong Jersey 2.x
Hướng dẫn Java Design Pattern – Abstract Factory
Java Program to Find MST (Minimum Spanning Tree) using Prim’s Algorithm
Introduction to Spring Cloud CLI
Model, ModelMap, and ModelAndView in Spring MVC
Query Entities by Dates and Times with Spring Data JPA
A Guide To UDP In Java
Registration – Activate a New Account by Email
Guide to Escaping Characters in Java RegExps
Java Program to Implement Find all Back Edges in a Graph
Java Program to Implement Circular Doubly Linked List
Spring Boot - Build Systems
Deploy a Spring Boot App to Azure
Java Program to Represent Graph Using 2D Arrays
Add Multiple Items to an Java ArrayList
Java Program to Implement Naor-Reingold Pseudo Random Function
String Operations with Java Streams
Guide to java.util.concurrent.BlockingQueue
Convert Hex to ASCII in Java
Rest Web service: Filter và Interceptor với Jersey 2.x (P1)
Java Program to Check Whether a Given Point is in a Given Polygon
Redirect to Different Pages after Login with Spring Security
Java Program to Implement Heap’s Algorithm for Permutation of N Numbers
Spring’s RequestBody and ResponseBody Annotations
A Quick Guide to Using Keycloak with Spring Boot
Java Program to Create a Minimal Set of All Edges Whose Addition will Convert it to a Strongly Conne...
Java Program to Implement String Matching Using Vectors
Java Program to Construct an Expression Tree for an Prefix Expression
Java Program to Perform Insertion in a 2 Dimension K-D Tree
An Intro to Spring Cloud Vault