CodeGrabber
{ USER }
posts: 23
last: 28-Apr-2008
TITLE: Merge Sort Algorithm
DESCRIPTION: Merge Sort Algorithm
Submitted: 09-Apr-2008 11:30:08 ( 32w 0d 5h ago ) Language: Java (*.java)
Views: 192 Lines of Code: 70 LINES
Rating:
rate: star1
star2
star3
star4
star5
dstar1
dstar2
dstar3
dstar4
dstar5  ( rated! )
  { 0.00 / 5 }
Difficulty: Intermediate
Bookmark
/* Author: 
   Date: 09-04-2008
   Filename: 
   Description: Merge Sort Algorithm
   History: 
*/


package com.chapter2;

public class MergeSortV2 {

	/**
	 * @param args
	 */
	static void Merge(int A[],int p, int q, int r)
	{
		int n1 = q-p+1;
		int n2 = r-q;
		int L[] = new int[n1+2];
		int R[] = new int[n2+2];
		for(int i = 1; i <= n1; i++)
		{
			L[i] = A[p+i-1];
		}
		for(int j = 1; j <= n2; j++)
		{
			R[j] = A[q+j];
		}
		L[n1+1] = Integer.MAX_VALUE;
		R[n2+1] = Integer.MAX_VALUE;
		int i = 1;
		int j = 1;
		for(int k = p; k <= r; k++)
		{
			if(L[i] < R[j])
			{
				A[k] = L[i];
				i++;
			}
			else
			{
				A[k] = R[j];
				j++;
			}
		}
	}
	static void MergeSort(int A[],int p, int r)
	{
		if(p<r)
		{
			int q = (p+r)/2;
			MergeSort(A, p, q);
			MergeSort(A, q+1, r);
			Merge(A, p, q, r);
			
		}
	}
	public static void main(String[] args) {
		// TODO Auto-generated method stub

		int arr[] = {6,23,33,1,5,77};
		MergeSort(arr,1,5);
		for(int i = 0; i < 6; i++)
		{
			System.out.println(arr[i]);
		}
	}

}