Java Program to Find the Median of two Sorted Arrays using Binary Search Approach

This is a Java Program to find median of two sorted arrays using binary search approach. In probability theory and statistics, a median is described as the number separating the higher half of a sample, a population, or a probability distribution, from the lower half. The median of a finite list of numbers can be found by arranging all the numbers from lowest value to highest value and picking the middle one. However size of both arrays must be equal. The time complexity of the following program is O (log n).

Here is the source code of the Java program to find median of two sorted arrays. The Java program is successfully compiled and run on a Windows system. The program output is also shown below.

/*
 * Java Program to Find the Median of two Sorted arrays using 
 * Binary Search Approach
 */
 
import java.util.Scanner;
 
public class MedianOfTwoSortedArrays
{
    public static void main(String[] args) 
    {
        Scanner scan = new Scanner(System.in);
        System.out.println("Enter number of elements in arrays");
        int N = scan.nextInt();
        int[] arr1 = new int[ N ];
        int[] arr2 = new int[ N ];
        System.out.println("Enter "+ N +" elements of array 1");
        for (int i = 0; i < N; i++)
            arr1[i] = scan.nextInt();
        System.out.println("Enter "+ N +" elements of array 2");
        for (int i = 0; i < N; i++)
            arr2[i] = scan.nextInt();
        int med = median(arr1, arr2);
        System.out.println("Median = "+ med);
     }
     public static int median(int[] arr1, int[] arr2)
     {
         int N = arr1.length;
         return median(arr1, 0, N -1 , arr2, 0, N - 1);
     }
     public static int median(int[] arr1, int l1, int h1, int[] arr2, int l2, int h2)
     {
         int mid1 = (h1 + l1 ) / 2;
         int mid2 = (h2 + l2 ) / 2;
 
         if (h1 - l1 == 1)
             return (Math.max(arr1[l1] , arr2[l2]) + Math.min(arr1[h1] , arr2[h2]))/2;
         else if (arr1[mid1] > arr2[mid2])
             return median(arr1, l1, mid1 , arr2, mid2 , h2);    
         else
             return median(arr1, mid1 , h1, arr2, l2 , mid2 );    
     }     
}
Enter number of elements in arrays
5
Enter 5 elements of array 1
1 12 15 26 38
Enter 5 elements of array 2
2 13 17 30 45
Median = 16

Related posts:

Java Program to Perform Encoding of a Message Using Matrix Multiplication
HandlerAdapters in Spring MVC
The DAO with JPA and Spring
Spring Autowiring of Generic Types
Registration with Spring Security – Password Encoding
Removing all Nulls from a List in Java
The “final” Keyword in Java
HttpAsyncClient Tutorial
OAuth2 for a Spring REST API – Handle the Refresh Token in AngularJS
Introduction to the Functional Web Framework in Spring 5
Java Program to Implement Interpolation Search Algorithm
Spring Boot Tutorial – Bootstrap a Simple Application
Java Program to Implement an Algorithm to Find the Global min Cut in a Graph
Spring Data JPA @Modifying Annotation
Difference Between Wait and Sleep in Java
Java Program to Describe the Representation of Graph using Adjacency Matrix
Java Program to Check whether Undirected Graph is Connected using BFS
Spring Boot - Servlet Filter
Java Web Services – Jersey JAX-RS – REST và sử dụng REST API testing tools với Postman
JUnit 5 @Test Annotation
Most commonly used String methods in Java
Java Program to Find the Longest Path in a DAG
Java Program to Implement Meldable Heap
@DynamicUpdate with Spring Data JPA
Java Program to Implement Threaded Binary Tree
Java Program to Check Whether an Input Binary Tree is the Sub Tree of the Binary Tree
Java Program to Implement Dijkstra’s Algorithm using Priority Queue
Java Program to Find the GCD and LCM of two Numbers
Abstract class và Interface trong Java
The XOR Operator in Java
Ways to Iterate Over a List in Java
Introduction to Spring Cloud OpenFeign