-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathMergeSort.java
More file actions
73 lines (60 loc) · 1.3 KB
/
MergeSort.java
File metadata and controls
73 lines (60 loc) · 1.3 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
public class MergeSort {
//for printing
public static void printArr(int arr[]) {
for(int i=0;i<arr.length;i++) {
System.out.print(arr[i]+" ");
}
System.out.println();
}
public static void mergesort(int arr[] ,int si,int ei) {
if(si>=ei) {
return;
}
//kaam
int mid = si + (ei - si) / 2;
//(si+ei)/2
mergesort(arr,si,mid);//left part
mergesort(arr,mid+1,ei); //right part
merge(arr ,si ,mid,ei);
}
//conquer part
public static void merge (int arr[],int si,int mid,int ei){
//left (0,3)=4 right (4,6)=3 =7 > 6-0+1
int temp[]=new int[ei-si+1];
int i =si;//iterator for left part
int j=mid+1;//iterator for right part
int k=0;//iterator for temp arr
while(i<=mid && j<=ei) {
if(arr[i]<arr[j]) {
temp[k]=arr[i];
i++;
}
else {
temp[k]=arr[j];
j++;
}
k++;
}
//left part
while(i<=mid) {
temp[k++]=arr[i++];
}
//right part
while(j<=ei) {
temp[k++]=arr[j++];
}
//copy temp to original array
for(k=0,i=si; k<temp.length; k++,i++) {
arr[i]=temp[k];
}
}
/*public static void mergeSort(int arr[],int si,int ei) {
int mid=si+(ei-si) /2;
mergeSort(arr,0,arr.length-1);
printArr(arr);*/
public static void main (String args[]) {
int arr[]= {6,3,9,5,2,8};
mergesort(arr, 0, arr.length - 1);
printArr(arr);
}
}