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:

Database Migrations with Flyway
Java Program to Implement Weight Balanced Tree
The Basics of Java Security
Query Entities by Dates and Times with Spring Data JPA
Using the Map.Entry Java Class
Spring Boot - Service Components
A Guide to WatchService in Java NIO2
Java Program to Implement Network Flow Problem
Java Program to Apply Above-Below-on Test to Find the Position of a Point with respect to a Line
Java Program to Implement Depth-limited Search
Java Program to Perform Insertion in a BST
Spring Security Login Page with React
Java Program to Implement Knapsack Algorithm
Guide to Java 8’s Collectors
Giới thiệu Google Guice – Aspect Oriented Programming (AOP)
Java Program to Implement the Binary Counting Method to Generate Subsets of a Set
Java Program to Implement LinkedHashMap API
Java Program to Perform Inorder Non-Recursive Traversal of a Given Binary Tree
Java Program to find the maximum subarray sum O(n^2) time(naive method)
A Guide to Spring Boot Admin
Guide to CopyOnWriteArrayList
Java Program to Implement Heap’s Algorithm for Permutation of N Numbers
Feign – Tạo ứng dụng Java RESTful Client
Java Program to Compute Cross Product of Two Vectors
Hướng dẫn Java Design Pattern – Iterator
Java Program to Implement Adjacency Matrix
Java Program to Find the Longest Subsequence Common to All Sequences in a Set of Sequences
Guide to java.util.concurrent.Future
Default Password Encoder in Spring Security 5
Java Program to Compute Discrete Fourier Transform Using the Fast Fourier Transform Approach
Spring Security Logout
Understanding Memory Leaks in Java