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:
Extract network card address
Guide to the Java Clock Class
Iterable to Stream in Java
Chuyển đổi từ HashMap sang ArrayList
Java Program to Perform Addition Operation Using Bitwise Operators
Hướng dẫn sử dụng luồng vào ra nhị phân trong Java
Java – Write to File
Toán tử trong java
Java Program to Check if it is a Sparse Matrix
Implementing a Binary Tree in Java
Java Program to Perform Searching Using Self-Organizing Lists
Giới thiệu Google Guice – Aspect Oriented Programming (AOP)
Getting Started with Custom Deserialization in Jackson
Đồng bộ hóa các luồng trong Java
Java 8 Stream findFirst() vs. findAny()
Java Program to Implement Quick Sort Using Randomization
Java Collections Interview Questions
Java Program to Implement ArrayDeque API
Introduction to Spring MVC HandlerInterceptor
Convert String to int or Integer in Java
Java Program to Find the Edge Connectivity of a Graph
Spring Data JPA Delete and Relationships
Spring Security Remember Me
A Guide to JUnit 5
Java Program to Implement ConcurrentSkipListMap API
Merging Two Maps with Java 8
Introduction to Spring Cloud Stream
Hướng dẫn Java Design Pattern – Mediator
Java Program to Perform integer Partition for a Specific Case
Learning and Improving Algorithm through contests - Antti Laaksonen
MyBatis with Spring
Debugging Reactive Streams in Java