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:
Retrieve User Information in Spring Security
Java Program to Implement ScapeGoat Tree
Lớp TreeMap trong Java
Java Program to Implement Tarjan Algorithm
Java Program to Perform Preorder Recursive Traversal of a Given Binary Tree
Java Program to Check if a Point d lies Inside or Outside a Circle Defined by Points a, b, c in a Pl...
Java Program to Delete a Particular Node in a Tree Without Using Recursion
Marker Interface trong Java
Guide to Dynamic Tests in Junit 5
Java Program to Check Whether a Directed Graph Contains a Eulerian Cycle
Java Web Services – JAX-WS – SOAP
Spring Data JPA Delete and Relationships
HashSet trong Java hoạt động như thế nào?
Java Program to Implement Find all Back Edges in a Graph
Spring Boot Actuator
Spring Data JPA @Query
Hướng dẫn Java Design Pattern – Factory Method
So sánh Array và ArrayList trong Java
Java Program to Compute Determinant of a Matrix
Java Program to Perform Finite State Automaton based Search
New Features in Java 14
Java Program to Implement Depth-limited Search
Test a REST API with Java
Flattening Nested Collections in Java
Beans and Dependency Injection
Giới thiệu SOAP UI và thực hiện test Web Service
Guide to java.util.Formatter
Java Program to implement Bit Set
A Guide to LinkedHashMap in Java
Java 8 – Powerful Comparison with Lambdas
Spring 5 Functional Bean Registration
Inheritance and Composition (Is-a vs Has-a relationship) in Java