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 Implement the Program Used in grep/egrep/fgrep
Java Program to Implement Merge Sort on n Numbers Without tail-recursion
Java Program to Find the Minimum Element of a Rotated Sorted Array using Binary Search approach
Ép kiểu trong Java (Type casting)
Guide to Java 8 groupingBy Collector
Java Program to Implement DelayQueue API
LinkedHashSet trong Java hoạt động như thế nào?
Java Program to Implement Attribute API
Java Program to Perform Postorder Recursive Traversal of a Given Binary Tree
Java Program to Implement Wagner and Fisher Algorithm for online String Matching
Java Program to Perform Optimal Paranthesization Using Dynamic Programming
REST Web service: HTTP Status Code và xử lý ngoại lệ RESTful web service với Jersey 2.x
Java Program to Describe the Representation of Graph using Adjacency List
Convert String to int or Integer in Java
Sắp xếp trong Java 8
Adding Parameters to HttpClient Requests
Runnable vs. Callable in Java
Spring Boot - Exception Handling
Spring Boot Security Auto-Configuration
Java Program to Print the Kind of Rotation the AVL Tree is Undergoing
Java Program to Perform Naive String Matching
Java Program to Describe the Representation of Graph using Incidence Matrix
Spring RestTemplate Request/Response Logging
Spring Security Remember Me
Hướng dẫn Java Design Pattern – Proxy
Partition a List in Java
OAuth2 for a Spring REST API – Handle the Refresh Token in AngularJS
HttpClient 4 Cookbook
Java Program to Implement Fermat Primality Test Algorithm
Java Program to Find Hamiltonian Cycle in an UnWeighted Graph
Life Cycle of a Thread in Java
Java Program to Implement Max-Flow Min-Cut Theorem