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:
So sánh HashMap và HashSet trong Java
Transactions with Spring and JPA
Guide to CountDownLatch in Java
Java InputStream to String
Spring WebClient Requests with Parameters
Java Program to Compute the Volume of a Tetrahedron Using Determinants
Java Program to Check Whether it is Weakly Connected or Strongly Connected for a Directed Graph
Hướng dẫn Java Design Pattern – Dependency Injection
Chuyển đổi từ HashMap sang ArrayList
How to Replace Many if Statements in Java
Properties with Spring and Spring Boot
Java Program to Implement Dijkstra’s Algorithm using Set
JPA/Hibernate Persistence Context
Rabin-Karp Algorithm for string matching
How To Serialize and Deserialize Enums with Jackson
New Features in Java 15
Java Program to Implement wheel Sieve to Generate Prime Numbers Between Given Range
Concrete Class in Java
Java Program to Find the Minimum Element of a Rotated Sorted Array using Binary Search approach
SOAP Web service: Upload và Download file sử dụng MTOM trong JAX-WS
Chuyển đổi Array sang ArrayList và ngược lại
Exploring the New Spring Cloud Gateway
Semaphore trong Java
Calling Stored Procedures from Spring Data JPA Repositories
Java Program to Implement D-ary-Heap
Spring Boot - Code Structure
Hướng dẫn sử dụng Java Generics
Java Program to Implement Jarvis Algorithm
Hướng dẫn sử dụng lớp Console trong java
Java Program to Implement Hash Tables chaining with Singly Linked Lists
Request a Delivery / Read Receipt in Javamail
Function trong Java 8