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:
Derived Query Methods in Spring Data JPA Repositories
Default Password Encoder in Spring Security 5
Check If a String Is Numeric in Java
Handling Errors in Spring WebFlux
Java Program to Perform Partial Key Search in a K-D Tree
Java Program to Implement Find all Forward Edges in a Graph
Spring Data JPA @Query
Java Program to Implement Skew Heap
Consuming RESTful Web Services
Intro to the Jackson ObjectMapper
HttpClient Timeout
Hướng dẫn Java Design Pattern – Builder
Guide to UUID in Java
XML-Based Injection in Spring
Assert an Exception is Thrown in JUnit 4 and 5
Introduction to Spring Cloud CLI
An Intro to Spring Cloud Vault
Java Program to Implement EnumMap API
Java Program to Check if any Graph is Possible to be Constructed for a Given Degree Sequence
Java Program to Implement the linear congruential generator for Pseudo Random Number Generation
Introduction to Spring Data JDBC
Hướng dẫn sử dụng biểu thức chính quy (Regular Expression) trong Java
Java Program to Implement Direct Addressing Tables
Getting Started with GraphQL and Spring Boot
Spring Security Login Page with React
Guide to java.util.concurrent.BlockingQueue
Java Program to Perform Searching Using Self-Organizing Lists
Spring Security Registration – Resend Verification Email
Practical Java Examples of the Big O Notation
Java Program to Implement Cubic convergence 1/pi Algorithm
Logging a Reactive Sequence
Using JWT with Spring Security OAuth