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 Implement the Vigenere Cypher
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 Implement a Binary Search Tree using Linked Lists
Java Program to Solve a Matching Problem for a Given Specific Case
Guide to System.gc()
Phân biệt JVM, JRE, JDK
Adding Parameters to HttpClient Requests
Java Program to Implement Efficient O(log n) Fibonacci generator
Checked and Unchecked Exceptions in Java
Flattening Nested Collections in Java
Spring Cloud Bus
Spring AMQP in Reactive Applications
Java Program to Implement Interpolation Search Algorithm
Converting Between Byte Arrays and Hexadecimal Strings in Java
Lập trình mạng với java
Spring Boot - Twilio
Getting Started with Custom Deserialization in Jackson
Java Program to Implement Stack API
LIKE Queries in Spring JPA Repositories
List Interface trong Java
Guide to java.util.concurrent.Locks
Java Program to Check whether Undirected Graph is Connected using BFS
Giới thiệu Aspect Oriented Programming (AOP)
Introduction to Spliterator in Java
Convert Hex to ASCII in Java
Spring Data Java 8 Support
Java Program to Implement Unrolled Linked List
Java Byte Array to InputStream
Wrapper Classes in Java
Mệnh đề if-else trong java
Java Program to Implement Hash Tables with Double Hashing
Guava Collections Cookbook