一、冒泡排序
- 定义
冒泡排序是指重复地遍历待排序的元素,依次比较两个相邻的元素,如果顺序(如从大到小、首字母从Z到A)错误就把他们交换过来。每次遍历都能使得一个位置的元素最终有序,遍历进行到没有相邻元素需要交换时结束。 - 代码实现
public int[] void bubbleSort(int arr[]){
boolean flag=true;
for(int i=0;i<arr.length-1;i++){
flag=true;
for(int j=arr.length-1;j>i;j--){
if(arr[j]<arr[j-1]){
int temp=arr[j-1];
arr[j-1]=arr[j];
arr[j]=temp;
flag=false;
}
}
if(flag){
return arr;
}
}
return arr;
}
二、插入排序
- 定义
插入排序是指在待排序的元素中,假设前面n-1(其中n>=2)个数已经是排好顺序的,现将第n个数插到前面已经排好的序列中,然后找到合适自己的位置,使得插入第n个数的这个序列也是排好顺序的。按照此法对所有元素进行插入,直到整个序列排为有序。 - 代码实现
public int[] insertSort(int arr[]) {
for (int i = 1; i < arr.length; i++) {
int insertValue = arr[i];
int insertIndex = i - 1;
for (int j = insertIndex; j >= 0; j--) {
if (insertValue <= arr[j]) {
arr[j + 1] = arr[j];
if (j == 0) {
arr[j] = insertValue;
}
} else {
arr[j + 1] = insertValue;
break;
}
}
}
return arr;
}
三、选择排序
- 定义
选择排序是指第一次从待排序的数据元素中选出最小(或最大)的一个元素,存放在序列的起始位置,然后再从剩余的未排序元素中寻找到最小(大)元素,然后放到已排序的序列的末尾。以此类推,直到全部待排序的数据元素的个数为零。 - 代码实现
public int[] selectSort(int arr[]){
for(int i=0;i<arr.length-1;i++){
int min=arr[i];
int count=i;
for(int j=i+1;j<arr.length;j++){
if(min>arr[j]){
min=arr[j];
count=j;
}
}
arr[count]=arr[i];
arr[i]=min;
}
return arr;
}
四、希尔排序
- 定义
希尔排序是把记录按下标的一定增量分组,对每组使用直接插入排序算法排序;随着增量逐渐减少,每组包含的关键词越来越多,当增量减至 1 时,整个文件恰被分成一组,算法便终止。 - 代码实现
public int[] shellSort(int arr[]) {
for (int gap = arr.length / 2; gap > 0; gap /= 2) {
for(int i=gap;i<arr.length;i++){
int insertValue=arr[i];
int insertIndex=i-gap;
for(int j=insertIndex;j>=0;j-=gap){
if(insertValue<=arr[j]){
arr[j+gap]=arr[j];
if(j<gap){
arr[j]=insertValue;
}
}else{
arr[j+gap]=insertValue;
break;
}
}
}
}
return arr;
}
五、合并排序
- 定义
合并排序法是将两个(或两个以上)有序表合并成一个新的有序表,即把待排序序列分为若干个子序列,每个子序列是有序的。然后再把有序子序列合并为整体有序序列。 - 代码实现
public int[] mergeSort(int arr[],int left,int right,int temp[]){
if(left<right){
int mid=(left+right)/2;
mergeSort(arr,left,mid,temp);
mergeSort(arr,mid+1,right,temp);
merge(arr,left,mid,right,temp);
}
return arr;
}
public void merge(int arr[],int left,int mid,int right,int temp[]){
int i=left;
int j=mid+1;
int index=0;
while(i<=mid&&j<=right){
if(arr[i]<=arr[j]){
temp[index++]=arr[i++];
}else{
temp[index++]=arr[j++];
}
}
if(i>mid){
while(j<=right){
temp[index++]=arr[j++];
}
}
if(j>right){
while(i<=mid){
temp[index++]=arr[i++];
}
}
index=0;
for(int count=left;count<=right;count++){
arr[count]=temp[index++];
}
}
六、快速排序
- 定义
快速排序是指通过一趟排序将要排序的数据分割成独立的两部分,其中一部分的所有数据都比另外一部分的所有数据都要小,然后再按此方法对这两部分数据分别进行快速排序,整个排序过程可以递归进行,以此达到整个数据变成有序序列。 - 代码实现
public int[] quickSort(int arr[],int left,int right){
if(left<right){
int j=Partition(arr,left,right);
quickSort(arr,left,j-1);
quickSort(arr,j+1,right);
}
return arr;
}
public int Partition(int arr[],int left,int right){
int standard = arr[left];
int i = left;
int j = right;
while (i < j) {
while (j > i && arr[j] > standard) {
j--;
}
while (i < j && arr[i] <= standard) {
i++;
}
swap(arr, i, j);
}
swap(arr, i, left);
return i;
}
private void swap(int[] arr, int i, int j) {
int temp = arr[i];
arr[i] = arr[j];
arr[j] = temp;
}
七、基数排序
- 定义
基数排序属于“分配式排序”,又称“桶子法”,顾名思义,它是透过键值的部份资讯,将要排序的元素分配至某些“桶”中,藉以达到排序的作用,基数排序法是属于稳定性的排序,其时间复杂度为O (nlog®m),其中r为所采取的基数,而m为堆数,在某些时候,基数排序法的效率高于其它的稳定性排序法。 - 代码实现
public int[] radixSort(int arr[], int cur, int max){
int m=(int)Math.pow(10,cur)/10;
int bucket[][]=new int[10][arr.length];
int bucketCount[]=new int[10];
for(int i=0;i<arr.length;i++){
int k=arr[i]/m%10;
bucket[k][bucketCount[k]]=arr[i];
bucketCount[k]++;
}
int count=0;
for(int i=0;i<10;i++){
for(int j=0;j<bucketCount[i];j++){
arr[count++]=bucket[i][j];
}
}
while(cur<max){
cur++;
radixSort(arr,cur,max);
}
return arr;
}
八、堆排序
- 定义
堆排序是指利用堆这种数据结构所设计的一种排序算法。堆是一个近似完全二叉树的结构,并同时满足堆积的性质:即子结点的键值或索引总是小于(或者大于)它的父节点。 - 代码实现
public int[] heapSort(int arr[]){
for(int i=arr.length/2-1;i>=0;i--){
adjustHeap(arr,i,arr.length);
}
for(int j=arr.length-1;j>0;j--){
int temp=arr[j];
arr[j]=arr[0];
arr[0]=temp;
adjustHeap(arr,0,j);
}
return arr;
}
public static void adjustHeap(int arr[],int i,int length){
int temp=arr[i];
for(int k=2*i+1;k<length;k=2*k+1){
if(k+1<length&&arr[k]<arr[k+1]){
k++;
}
if(arr[k]>temp){
arr[i]=arr[k];
i=k;
}else {
break;
}
}
arr[i]=temp;
}
九、各排序算法复杂度总结
