-
Notifications
You must be signed in to change notification settings - Fork 344
/
Copy pathShellSort.cpp
52 lines (49 loc) · 1.76 KB
/
ShellSort.cpp
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
/*
Short Introduction:-
Shell sort is a highly efficient sorting algorithm and is based on insertion sort algorithm.
This algorithm avoids large shifts as in case of insertion sort, if the smaller value is to the far right
and has to be moved to the far left.This algorithm uses insertion sort on a widely spread elements, first to sort
them and then sorts the less widely spaced elements. This spacing is termed as interval.
Complexities:-
Worst case time complexity = O(n2)
Best case complexity = O(nlog(n)).
Space complexity = O(1).
*/
#include<iostream>
using namespace std;
/*Method to sort the list/array*/
void shellSort(int sort[],int size){
for(int gap=size/2;gap>0;gap/=2){
for(int i=gap;i<size;i++){
int temp=sort[i];
int j;
for(j=i;j>=gap&&sort[j-gap]>temp;j-=gap){
sort[j]=sort[j-gap];
}
sort[j]=temp;
}
}
}
//main program
int main(){
int size;
cout<<"Enter the size of the array: ";
cin>>size;
int sort[size];
cout<<"Enter the Elements to be sorted:";
for(int i=0;i<size;i++){
cin>>sort[i];
}
shellSort(sort,size);
cout<<"Array after sorting is: ";
for(int i=0;i<size;i++){
cout<<sort[i]<<" ";
}
cout<<endl;
return 0;
}
/* Output
Enter the size of the array: 5
9 5 8 1 4
Array after sorting is: 1 4 5 8 9
*/