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:
A Guide to TreeMap in Java
Java Program to Implement Threaded Binary Tree
Java Program to Perform Cryptography Using Transposition Technique
Java Program to Implement Graph Structured Stack
Hướng dẫn Java Design Pattern – MVC
Create Java Applet to Simulate Any Sorting Technique
XML Serialization and Deserialization with Jackson
Java Program to Implement Hopcroft Algorithm
Java Program to Perform Left Rotation on a Binary Search Tree
Changing Annotation Parameters At Runtime
Java Program to Check whether Undirected Graph is Connected using DFS
Java Program to Find the Median of two Sorted Arrays using Binary Search Approach
Spring Boot - Sending Email
New Features in Java 15
Guide to the Java TransferQueue
Binary Search
Java Program to Implement Patricia Trie
Adding Shutdown Hooks for JVM Applications
A Guide to Java 9 Modularity
Java Program to Implement CountMinSketch
Java Program to Implement RoleList API
Semaphore trong Java
Reading an HTTP Response Body as a String in Java
Java Program to Solve a Matching Problem for a Given Specific Case
JUnit 5 @Test Annotation
Kruskal's Algorithm
Custom Exception trong Java
Java Program to Implement Attribute API
Hướng dẫn Java Design Pattern – Prototype
Guide to Spring Cloud Kubernetes
Spring Cloud AWS – S3
Auditing with JPA, Hibernate, and Spring Data JPA