Java Merge Sort but make it read the data 12, 11, 13, 5, 6, 7 from a file not an array    /* Java program for Merge Sort */ class MergeSort {     // Merges two subarrays of arr[].     // First subarray is arr[l..m]     // Second subarray is arr[m+1..r]     void merge(int arr[], int l, int m, int r)     {         // Find sizes of two subarrays to be merged         int n1 = m - l + 1;         int n2 = r - m;           /* Create temp arrays */         int L[] = new int[n1];         int R[] = new int[n2];           /*Copy data to temp arrays*/         for (int i = 0; i < n1; ++i)             L[i] = arr[l + i];         for (int j = 0; j < n2; ++j)             R[j] = arr[m + 1 + j];           /* Merge the temp arrays */           // Initial indexes of first and second subarrays         int i = 0, j = 0;           // Initial index of merged subarray array         int k = l;         while (i < n1 && j < n2) {             if (L[i] <= R[j]) {                 arr[k] = L[i];                 i++;             }             else {                 arr[k] = R[j];                 j++;             }             k++;         }           /* Copy remaining elements of L[] if any */         while (i < n1) {             arr[k] = L[i];             i++;             k++;         }           /* Copy remaining elements of R[] if any */         while (j < n2) {             arr[k] = R[j];             j++;             k++;         }     }       // Main function that sorts arr[l..r] using     // merge()     void sort(int arr[], int l, int r)     {         if (l < r) {             // Find the middle point             int m = l + (r - l) / 2;               // Sort first and second halves             sort(arr, l, m);             sort(arr, m + 1, r);               // Merge the sorted halves             merge(arr, l, m, r);         }     }       /* A utility function to print array of size n */     static void printArray(int arr[])     {         int n = arr.length;         for (int i = 0; i < n; ++i)             System.out.print(arr[i] + " ");         System.out.println();     }       // Driver code     public static void main(String args[])     {         int arr[] = { 12, 11, 13, 5, 6, 7 }; // make it read from a file instead of having this           System.out.println("Given Array");         printArray(arr);           MergeSort ob = new MergeSort();         ob.sort(arr, 0, arr.length - 1);           System.out.println("\nSorted array");         printArray(arr);     } }
Java Merge Sort but make it read the data 12, 11, 13, 5, 6, 7 from a file not an array /* Java program for Merge Sort */ class MergeSort { // Merges two subarrays of arr[]. // First subarray is arr[l..m] // Second subarray is arr[m+1..r] void merge(int arr[], int l, int m, int r) { // Find sizes of two subarrays to be merged int n1 = m - l + 1; int n2 = r - m; /* Create temp arrays */ int L[] = new int[n1]; int R[] = new int[n2]; /*Copy data to temp arrays*/ for (int i = 0; i < n1; ++i) L[i] = arr[l + i]; for (int j = 0; j < n2; ++j) R[j] = arr[m + 1 + j]; /* Merge the temp arrays */ // Initial indexes of first and second subarrays int i = 0, j = 0; // Initial index of merged subarray array int k = l; while (i < n1 && j < n2) { if (L[i] <= R[j]) { arr[k] = L[i]; i++; } else { arr[k] = R[j]; j++; } k++; } /* Copy remaining elements of L[] if any */ while (i < n1) { arr[k] = L[i]; i++; k++; } /* Copy remaining elements of R[] if any */ while (j < n2) { arr[k] = R[j]; j++; k++; } } // Main function that sorts arr[l..r] using // merge() void sort(int arr[], int l, int r) { if (l < r) { // Find the middle point int m = l + (r - l) / 2; // Sort first and second halves sort(arr, l, m); sort(arr, m + 1, r); // Merge the sorted halves merge(arr, l, m, r); } } /* A utility function to print array of size n */ static void printArray(int arr[]) { int n = arr.length; for (int i = 0; i < n; ++i) System.out.print(arr[i] + " "); System.out.println(); } // Driver code public static void main(String args[]) { int arr[] = { 12, 11, 13, 5, 6, 7 }; // make it read from a file instead of having this System.out.println("Given Array"); printArray(arr); MergeSort ob = new MergeSort(); ob.sort(arr, 0, arr.length - 1); System.out.println("\nSorted array"); printArray(arr); } }
Database System Concepts
7th Edition
ISBN:9780078022159
Author:Abraham Silberschatz Professor, Henry F. Korth, S. Sudarshan
Publisher:Abraham Silberschatz Professor, Henry F. Korth, S. Sudarshan
Chapter1: Introduction
Section: Chapter Questions
Problem 1PE 
Related questions
Question
100%
Java Merge Sort but make it read the data 12, 11, 13, 5, 6, 7 from a file not an array
/* Java program for Merge Sort */
class MergeSort {
    // Merges two subarrays of arr[].
    // First subarray is arr[l..m]
    // Second subarray is arr[m+1..r]
    void merge(int arr[], int l, int m, int r)
    {
        // Find sizes of two subarrays to be merged
        int n1 = m - l + 1;
        int n2 = r - m;
        /* Create temp arrays */
        int L[] = new int[n1];
        int R[] = new int[n2];
        /*Copy data to temp arrays*/
        for (int i = 0; i < n1; ++i)
            L[i] = arr[l + i];
        for (int j = 0; j < n2; ++j)
            R[j] = arr[m + 1 + j];
        /* Merge the temp arrays */
        // Initial indexes of first and second subarrays
        int i = 0, j = 0;
        // Initial index of merged subarray array
        int k = l;
        while (i < n1 && j < n2) {
            if (L[i] <= R[j]) {
                arr[k] = L[i];
                i++;
            }
            else {
                arr[k] = R[j];
                j++;
            }
            k++;
        }
        /* Copy remaining elements of L[] if any */
        while (i < n1) {
            arr[k] = L[i];
            i++;
            k++;
        }
        /* Copy remaining elements of R[] if any */
        while (j < n2) {
            arr[k] = R[j];
            j++;
            k++;
        }
    }
    // Main function that sorts arr[l..r] using
    // merge()
    void sort(int arr[], int l, int r)
    {
        if (l < r) {
            // Find the middle point
            int m = l + (r - l) / 2;
            // Sort first and second halves
            sort(arr, l, m);
            sort(arr, m + 1, r);
            // Merge the sorted halves
            merge(arr, l, m, r);
        }
    }
    /* A utility function to print array of size n */
    static void printArray(int arr[])
    {
        int n = arr.length;
        for (int i = 0; i < n; ++i)
            System.out.print(arr[i] + " ");
        System.out.println();
    }
    // Driver code
    public static void main(String args[])
    {
        int arr[] = { 12, 11, 13, 5, 6, 7 }; // make it read from a file instead of having this
        System.out.println("Given Array");
        printArray(arr);
        MergeSort ob = new MergeSort();
        ob.sort(arr, 0, arr.length - 1);
        System.out.println("\nSorted array");
        printArray(arr);
    }
}
/* This code is contributed by Rajat Mishra */
Expert Solution
Step 1
Program Approach:
- Step 1: Create class with the name of MergeSort.
 - Step 2: Create mergeSort method with three parameters.
 - Step 3: If the left index of array is less than the right index, calculate its mid point
 - Step 4: Divide complete array into equal halves till data
 - Step 5: After dividing array values start merging based on comparison.
 - Step 6: After all comparisons list will sort
 - Step 7: Display sorted list through file
 - Step 8: End of the program
 
Step by step
Solved in 5 steps with 3 images

Knowledge Booster
Learn more about 
Need a deep-dive on the concept behind this application? Look no further. Learn more about this topic, computer-science and related others by exploring similar questions and additional content below.Recommended textbooks for you

Database System Concepts
Computer Science
ISBN:
9780078022159
Author:
Abraham Silberschatz Professor, Henry F. Korth, S. Sudarshan
Publisher:
McGraw-Hill Education

Starting Out with Python (4th Edition)
Computer Science
ISBN:
9780134444321
Author:
Tony Gaddis
Publisher:
PEARSON

Digital Fundamentals (11th Edition)
Computer Science
ISBN:
9780132737968
Author:
Thomas L. Floyd
Publisher:
PEARSON

Database System Concepts
Computer Science
ISBN:
9780078022159
Author:
Abraham Silberschatz Professor, Henry F. Korth, S. Sudarshan
Publisher:
McGraw-Hill Education

Starting Out with Python (4th Edition)
Computer Science
ISBN:
9780134444321
Author:
Tony Gaddis
Publisher:
PEARSON

Digital Fundamentals (11th Edition)
Computer Science
ISBN:
9780132737968
Author:
Thomas L. Floyd
Publisher:
PEARSON

C How to Program (8th Edition)
Computer Science
ISBN:
9780133976892
Author:
Paul J. Deitel, Harvey Deitel
Publisher:
PEARSON

Database Systems: Design, Implementation, & Manag…
Computer Science
ISBN:
9781337627900
Author:
Carlos Coronel, Steven Morris
Publisher:
Cengage Learning

Programmable Logic Controllers
Computer Science
ISBN:
9780073373843
Author:
Frank D. Petruzella
Publisher:
McGraw-Hill Education