Java Program to find the number of occurrences of a given number using Binary Search approach

This is a Java Program to find number of occurences of a given number using binary search approach. The time complexity of the following program is O (log n).

Here is the source code of the Java program to find number of occurences of a given number using binary search approach. The Java program is successfully compiled and run on a Windows system. The program output is also shown below.

/*
 *    Java Program to Find the Number of occurrences of a given Number using Binary Search approach
 */
 
import java.util.Scanner;
 
public class NumberOfOccurences
{
    public static void main(String[] args) 
    {
        Scanner scan = new Scanner(System.in);
        System.out.println("Enter number of elements in sorted array");
        int N = scan.nextInt();
        int[] arr = new int[ N ];
        /* Accept N elements */
        System.out.println("Enter "+ N +" sorted elements");
        for (int i = 0; i < N; i++)
            arr[i] = scan.nextInt();
        System.out.println("Enter number to find occurences");
        int num = scan.nextInt();
 
        int f = occur(arr, num);
        if (f == -1)
            System.out.println("No occurence");
        else 
            System.out.println("Occurences = "+ f);
    }    
    public static int occur(int[] arr, int num)
    {
        /* find first index */
        int l1 = first(arr, num);
        /* find last index */
        int l2 = last(arr, num);
        if (l1 == -1 || l2 == -1)
            return -1;
        return l2 - l1 + 1;
    }
    public static int first(int[] arr, int num)
    {
        if (arr[0] == num)
            return 0;
        int start = 0, end = arr.length - 1;
        int mid = (start + end) / 2;
        int flag = 0;
        while (!(arr[mid] == num && arr[mid - 1] < arr[mid]))
        {
            if (start == end)
            {
                flag = 1;
                break;
            }
            if (arr[mid] >= num)
                end = mid - 1;
            if (arr[mid] < num)
                start = mid + 1;
            mid = (start + end) / 2;
        }
        if (flag == 0)
            return mid;
        return -1;        
    }
    public static int last(int[] arr, int num)
    {
        if (arr[arr.length - 1] == num)
            return arr.length - 1;
        int start = 0, end = arr.length - 1;
        int mid = (start + end) / 2;
        int flag = 0;
        while (!(arr[mid] == num && arr[mid + 1] > arr[mid]))
        {
            if (start == end)
            {
                flag = 1;
                break;
            }
            if (arr[mid] > num)
                end = mid - 1;
            if (arr[mid] <= num)
                start = mid + 1;
            mid = (start + end) / 2;
        }
        if (flag == 0)
            return mid;
        return -1;        
    }
}
Enter number of elements in sorted array
10
Enter 10 sorted elements
1 1 3 3 3 3 4 4 4 5
Enter number to find occurences
3
Occurences = 4
 
 
Enter number of elements in sorted array
10
Enter 10 sorted elements
1 1 3 3 3 3 4 4 4 5
Enter number to find occurences
5
Occurences = 1

Related posts:

Guide to Mustache with Spring Boot
Runnable vs. Callable in Java
Working with Tree Model Nodes in Jackson
Spring Security OAuth Login with WebFlux
HandlerAdapters in Spring MVC
Concatenating Strings In Java
Java Program to do a Depth First Search/Traversal on a graph non-recursively
Prevent Brute Force Authentication Attempts with Spring Security
ETL with Spring Cloud Data Flow
Using a Mutex Object in Java
Java Program to Apply Above-Below-on Test to Find the Position of a Point with respect to a Line
String Joiner trong Java 8
Java Program to Find Number of Spanning Trees in a Complete Bipartite Graph
Java Program to Implement Selection Sort
Java Program to Generate a Graph for a Given Fixed Degree Sequence
@DynamicUpdate with Spring Data JPA
Java Program to Implement the Checksum Method for Small String Messages and Detect
Fixing 401s with CORS Preflights and Spring Security
Java Program to Check if a Given Graph Contain Hamiltonian Cycle or Not
Java Program to Implement Solovay Strassen Primality Test Algorithm
Number Formatting in Java
Overview of Spring Boot Dev Tools
Java Program to Perform Complex Number Multiplication
Java Program to add two large numbers using Linked List
Spring Boot - Eureka Server
Hướng dẫn Java Design Pattern – Service Locator
Một số ký tự đặc biệt trong Java
Java Program to Check for balanced parenthesis by using Stacks
Java Program to Implement Levenshtein Distance Computing Algorithm
Spring MVC and the @ModelAttribute Annotation
Java Program to Check if a Given Set of Three Points Lie on a Single Line or Not
Giới thiệu về Stream API trong Java 8