插入排序:
稳定
最优时间复杂度:O(n) 此时数列顺序排列
最差时间复杂度:O(n^2) 此时数列逆序排列
插入排序的思想:固定一个元素a,分别比较a之前的元素,如果a之前的元素比a大,则元素后移,将a插入比a小的元素后面。
要理解插入排序,实际上递归和不递归的思想是个相反的过程,递归的最后一层相当于非递归循环的第一层
递归版的插入排序:
#include<stdio.h>
#include<stdlib.h>
void Insert(int *a,int p,int q)
{
int key;
key=a[q+1];
int j;
j=q;
while(j>=0 &&a[j]>key)
{
a[j+1]=a[j];
j--;
}
a[j+1]=key;
}
void Recursive_InsertSort(int *a,int p,int q)
{
if(p<q)
{
Recursive_InsertSort(a,p,q-1);
Insert(a,p,q-1);
}
}
int main()
{
int a[10]={1,5,7,9,8,2,6,4,0,3};
int b[10];
int i,j,tem;
Recursive_InsertSort(a,0,10);
for(i=0;i<10;i++)
{
printf("%d ",a[i]);
}
system("pause");
}
非递归版插入排序
#include<stdio.h>
#include<stdlib.h>
int main()
{
int a[10]={1,5,7,9,8,2,6,4,0,3};
int b[10];
int i,j,tem;
for(i=1;i<10;i++)
{
tem=a[i];
j=i-1;
printf("ai1=%d\n",a[i]);
printf("tem1=%d\n",tem);
while(a[j]>tem&&j>=0) //这里只能用tem而不能用a[i]
{
printf("ai=%d\n",a[i]);
printf("tem=%d\n",tem);
a[j+1]=a[j];
j--;
}
a[j+1]=tem;
}
for(i=0;i<10;i++)
{
printf("%d ",a[i]);
}
system("pause");
}
冒泡排序:
稳定
最优时间复杂度:O(n^2)
最差时间复杂度:O(n^2)
冒泡排序算法的思想是每一次循环分别让i...n中的最小值到通过交换到达i点。
递归版冒泡排序算法:
#include<stdio.h>
#include<stdlib.h>
void Insert(int *a,int p,int q)
{
int i,j,tem;
for(i=p;i<q;i++)
{
if(a[i-1]>a[i])
{
tem=a[i-1];
a[i-1]=a[i];
a[i]=tem;
}
}
}
void Recursive_BubbleSort(int *a,int p,int q)
{
if(p<q)
{
Insert(a,p,q);
Recursive_BubbleSort(a,p,q-1);
}
}
int main()
{
int a[10]={5,1,7,9,8,2,6,4,0,3};
int b[10];
int i,j,tem;
Recursive_BubbleSort(a,1,10);
for(i=0;i<10;i++)
{
printf("%d ",a[i]);
}
system("pause");
}
冒泡排序算法:
#include<stdio.h>
#include<stdlib.h>
void BubbleSort(int *a,int n)
{
int tem,i,j;
for(i=0;i<n;i++)
{
for(j=n-1;j>i;j--)
{
if(a[j]<a[j-1])
{
tem=a[j];
a[j]=a[j-1];
a[j-1]=tem;
}
}
}
}
int main()
{
int a[10]={1,5,7,9,8,2,6,4,0,3};
int b[10];
int i,j,tem;
BubbleSort(a,10);
for(i=0;i<10;i++)
{
printf("%d ",a[i]);
}
system("pause");
}
选择排序:
不稳定
最优时间复杂度:O(n^2)
最差时间复杂度:O(n^2)
选择排序算法的思想是每一次循环分别让i...n中的最小值到通过交换到达i点,与冒泡算法不同的是,冒泡算法是与相邻元素交换。#include<stdio.h>
#include<stdlib.h>
void SelectSort(int *a,int m,int n)
{
int i,j,min,tem;
for(i=m;i<n;i++)
{
min=i;
for(j=i+1;j<n;j++)
{
if(a[min]>a[j])
{
min=j;
}
}
tem=a[min];
a[min]=a[i];
a[i]=tem;
}
}
int main()
{
int a[10]={5,1,7,9,8,2,6,4,0,3};
int b[10];
int i,j,tem;
SelectSort(a,0,10);
for(i=0;i<10;i++)
{
printf("%d ",a[i]);
}
system("pause");
}