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:
Java Program to Implement Stack using Linked List
Java Program to Check whether Directed Graph is Connected using BFS
Adding Shutdown Hooks for JVM Applications
Java Program to Perform Deletion in a BST
Creating Docker Images with Spring Boot
Hướng dẫn Java Design Pattern – Composite
Changing Annotation Parameters At Runtime
Convert Character Array to String in Java
Java Program to Check Cycle in a Graph using Graph traversal
Introduction to Java Serialization
Spring MVC and the @ModelAttribute Annotation
Guide to System.gc()
Hướng dẫn Java Design Pattern – Null Object
Giới thiệu Google Guice – Binding
Java Program to Find MST (Minimum Spanning Tree) using Kruskal’s Algorithm
Intro to Spring Boot Starters
The StackOverflowError in Java
Java Program to Implement Knapsack Algorithm
Java Program to Implement Tarjan Algorithm
Java Program to Implement Doubly Linked List
Java Program to Create a Random Linear Extension for a DAG
Mockito and JUnit 5 – Using ExtendWith
Java Program to Construct an Expression Tree for an Infix Expression
Java Program to Implement Splay Tree
Tránh lỗi NullPointerException trong Java như thế nào?
Spring Data MongoDB Transactions
Spring Boot - Enabling HTTPS
Hướng dẫn tạo và sử dụng ThreadPool trong Java
Spring Boot - Admin Client
Generic Constructors in Java
A Guide to JUnit 5 Extensions
Add Multiple Items to an Java ArrayList