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:
Creating a Web Application with Spring 5
Java Program to Implement Variable length array
Spring REST API + OAuth2 + Angular
Java Program to Implement Stack API
Custom Thread Pools In Java 8 Parallel Streams
Java Stream Filter with Lambda Expression
Java Program to Implement Coppersmith Freivald’s Algorithm
Spring Boot - Cloud Configuration Client
Guide to DelayQueue
Java Program to Implement PriorityQueue API
Java Program to Implement WeakHashMap API
Explain about URL and HTTPS protocol
How to Count Duplicate Elements in Arraylist
Marker Interface trong Java
Sereja and Algorithm
How to Iterate Over a Stream With Indices
XML-Based Injection in Spring
Java Program to Implement LinkedTransferQueue API
Java Program to Generate Randomized Sequence of Given Range of Numbers
Spring Boot - Code Structure
Functional Interface trong Java 8
Overview of Spring Boot Dev Tools
Spring MVC Setup with Kotlin
Java Program to Implement Depth-limited Search
Java Program to Generate Random Numbers Using Middle Square Method
Java Program to Implement Euler Circuit Problem
Java Multi-line String
Tạo chương trình Java đầu tiên sử dụng Eclipse
Spring Boot - Enabling Swagger2
More Jackson Annotations
Java Program to Implement Gaussian Elimination Algorithm
Multipart Upload with HttpClient 4