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:
Java Program to Perform Arithmetic Operations on Numbers of Size
LIKE Queries in Spring JPA Repositories
Java – Combine Multiple Collections
New Features in Java 12
Getting Started with Forms in Spring MVC
Spring REST with a Zuul Proxy
Java 8 – Powerful Comparison with Lambdas
Guide to the Java Clock Class
Java Program to Create a Random Graph Using Random Edge Generation
Java Program to Implement Graph Structured Stack
Send email with authentication
Lấy ngày giờ hiện tại trong Java
Java Program to Implement Meldable Heap
Java Program to Implement ArrayBlockingQueue API
Using a Spring Cloud App Starter
Java Program to Implement Graham Scan Algorithm to Find the Convex Hull
Java Program to Implement VList
Java Program to Implement the Vigenere Cypher
Java Program to find the maximum subarray sum using Binary Search approach
Java Program to Implement Double Order Traversal of a Binary Tree
Java Program to Generate Date Between Given Range
Sử dụng Fork/Join Framework với ForkJoinPool trong Java
Check If Two Lists are Equal in Java
Quick Guide to Spring Bean Scopes
Biến trong java
String Initialization in Java
Java Program to Implement Double Ended Queue
Spring WebClient Filters
Spring Cloud – Securing Services
How to Return 404 with Spring WebFlux
Testing an OAuth Secured API with Spring MVC
Java Program to Implement Ternary Search Algorithm