c语方学习笔记六

排序
sb东西
算法(alorithm) 解决一类计算问题




插入排序
示例代码:
#include <stdio.h>
#define LEN 5
int a[LEN]={10,5,2,4,7};
void insertion_sort(void){
int i,j,key;
for(i=1;i<LEN;i++){
printf("element:%d,%d,%d,%d,%d\n",a[0],a[1],a[2],a[3],a[4]);
key=a[i];
j=i-1;
while(j>=0&&a[j]>key){
a[j+1]=a[j];
j--;
}
a[j+1]=key;
}
printf("end:%d,%d,%d,%d,%d\n",a[0],a[1],a[2],a[3],a[4]);
}
int main(void){
insertion_sort();
return 0;
}




算法的时间复杂度

常见:
o(lgn) o(sqrt(n)) o(n) o(nlgn) o(n2) o(2n) o(n!)



归并排序
首先把长度为len的序列分为两个子序列
对两个子序列分别进行归并排序
两个序列合并为一个

#include<stdio.h>
#define LEN 8
int a[LEN]={5,2,4,7,1,3,2,6};
void merge(int start,int mid,int end){
int n1=mid-start+1;
int n2=end-mid;
int left[n1],right[n2];
int i,j,k;
for(i=0;i<n1;i++){
left[i]=a[start+i];
}
for(j=0;j<n2;j++){
right[j]=a[mid+1+j];
}
i=j=0;
k=start;
while(i<n1&&j<n2){
if(left[i]<right[j]){
a[k++]=left[i++];
}else{
a[k++]=right[j++];
}
}
while(i<n1){
a[k++]=left[i++];
}
while(j<n2){
a[k++]=right[j++];
}
}
void sort(int start,int end){
int mid;
if(start<end){
mid=(start+end)/2;
printf("sort (%d=%d,%d=%d) %d %d %d %d %d %d %d %d


\n",start,mid,mid+1,end,a[0],a[1],a[2],a[3],a[4],a[5],a[6],a[7]);
sort(start,mid);
sort(mid+1,end);
merge(start,mid,end);
printf("sort (%d=%d,%d=%d) %d %d %d %d %d %d %d %d


\n",start,mid,mid+1,end,a[0],a[1],a[2],a[3],a[4],a[5],a[6],a[7]);
}

}
int main(void){
sort(0,LEN-1);
return 0;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值