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:
Giới thiệu Design Patterns
Case-Insensitive String Matching in Java
Java Program to Implement Merge Sort on n Numbers Without tail-recursion
HttpClient 4 – Send Custom Cookie
Java Program to Implement Fenwick Tree
Java Program to Implement D-ary-Heap
Queue và PriorityQueue trong Java
Assert an Exception is Thrown in JUnit 4 and 5
Create Java Applet to Simulate Any Sorting Technique
Java Program to Construct an Expression Tree for an Infix Expression
The Registration Process With Spring Security
Java Program to implement Bit Matrix
Tạo số và chuỗi ngẫu nhiên trong Java
Java Program to Perform Preorder Non-Recursive Traversal of a Given Binary Tree
Java Program to Find kth Largest Element in a Sequence
Java NIO2 Path API
Overflow and Underflow in Java
Java Program to Implement Graham Scan Algorithm to Find the Convex Hull
Các chương trình minh họa sử dụng Cấu trúc điều khiển trong Java
Java Program to Implement CopyOnWriteArrayList API
4 tính chất của lập trình hướng đối tượng trong Java
Giới thiệu Google Guice – Aspect Oriented Programming (AOP)
Tránh lỗi ConcurrentModificationException trong Java như thế nào?
Model, ModelMap, and ModelAndView in Spring MVC
Java Program to Compute Discrete Fourier Transform Using the Fast Fourier Transform Approach
Sorting in Java
Chuyển đổi từ HashMap sang ArrayList
Disable Spring Data Auto Configuration
Loại bỏ các phần tử trùng trong một ArrayList như thế nào trong Java 8?
A Guide to Spring Boot Admin
Spring Boot - Google OAuth2 Sign-In
REST Web service: Basic Authentication trong Jersey 2.x