前言
个人小记
一、原理
将因为判断而产生的n方替换掉,变为遍历与交换的n
二、代码
#include<stdio.h>
#include <stdlib.h>
#include <string.h>
#include <time.h>
#define MAX_ARR 100000
#define swap(a,b)\
{\
__typeof(a) __c=a;\
a=b,b=__c;\
}
#define TEST(func,arr,l,n)\
{\
printf("test:%s\n",#func);\
int* t=(int *)malloc(sizeof(int)*n);\
memcpy(t,arr,n);\
long long a=clock();\
func(t,l,n);\
long long b=clock();\
if(check(t,n))printf("OK %lldms\n",(b-a)*1000/CLOCKS_PER_SEC);\
else printf("FAIL\n");\
free(t);\
}
int check(int* t,int n)
{
for(int i=1;i<n;i++)
{
if(t[i-1]>t[i])return 0;
}
return 1;
}
int *init_arr(int n)
{
int *arr=(int *)malloc(sizeof(int)*n);
for(int i=0;i<n;i++)arr[i]=rand()%100000;
return arr;
}
void CU_insert(int *arr,int l,int r)
{
int min=l;
for(int i=l+1;i<r;i++)if(arr[min]>arr[i])min=i;
while(min>l)
{
swap(arr[min],arr[min-1]);
min=min-1;
}
for(int i=l+1;i<r;i++)
{
int j=i;
while(arr[j]<arr[j-1])
{
swap(arr[j],arr[j-1]);
j=j-1;
}
}
return ;
}
void insert(int *arr,int l,int r)
{
for(int i=l+1;i<r;i++)
{
int j=i;
while(j>l&&arr[j]<arr[j-1])
{
swap(arr[j],arr[j-1]);
j=j-1;
}
}
return ;
}
int main()
{
int *arr=init_arr(MAX_ARR);
TEST(CU_insert,arr,0,MAX_ARR);
TEST(insert,arr,0,MAX_ARR);
free(arr);
return 0;
}
二、测试结果
test:CU_insert
OK 8343ms
test:insert
OK 9237ms