排序算法从入门到精通之一公用文件

从这篇文章开始,我将陆续介绍几种排序算法,内容包括算法描述,源代码,性能测试报告等。要介绍的排序算法有冒泡排序,选择排序,插入排序,希尔排序,快速排序,归并排序,堆排序。

所有的代码可包括在一个VC工程文件之中。这里写给出这些排序子程序使用的公共头文件和时间测试函数。所有代码为标准的C语言代码。我这里没有使用C++的特性。先给出公共头文件sorts.h

#ifndef BUBBLE_SORT_DEF_2018_02_21
#define BUBBLE_SORT_DEF_2018_02_21

#include <stdint.h>
 
typedef int		ELE_TYPE;
typedef	int*	ELE_PTR;
 
#define BOOL int
#define FALSE 0
#define TRUE 1
 
#define MAX_LEN	2000000
#define INSERT_SORT_THRESHOLD	16
 
extern uint64_t getCurrentTimeMsec();
extern void print_array(ELE_TYPE arr[], int len);
 
extern void insert_sort(ELE_TYPE arr[], int len);
extern void shell_sort(ELE_TYPE arr[], int len);
extern void merge_sort(ELE_TYPE arr[], int len);
extern void quick_sort(ELE_TYPE arr[], int len);
extern void heap_sort(ELE_TYPE arr[], int len);
 
#endif

再给出一个c文件common.c, 这个文件包含2个函数,用于测量时间和打印数组,以验证排序后的内容是否正确。

#define _CRT_SECURE_NO_WARNINGS

#include <stdio.h>
#include <stdlib.h>

#ifdef _WIN32
    #include <winsock2.h>
    #include <time.h>
#else
    #include <sys/time.h>
#endif

#include "sorts.h"
 
uint64_t getCurrentTimeMsec()
{
#ifdef _WIN32
        struct timeval tv;
        time_t clock;
        struct tm tm;
        SYSTEMTIME wtm;
 
        GetLocalTime(&wtm);
        tm.tm_year = wtm.wYear - 1900;
        tm.tm_mon = wtm.wMonth - 1;
        tm.tm_mday = wtm.wDay;
        tm.tm_hour = wtm.wHour;
        tm.tm_min = wtm.wMinute;
        tm.tm_sec = wtm.wSecond;
        tm.tm_isdst = -1;
        clock = mktime(&tm);
        tv.tv_sec = clock;
        return ((uint64_t)tv.tv_sec * 1000 + (uint64_t)wtm.wMilliseconds);
#else
        struct timeval tv;
        gettimeofday(&tv,NULL);
        return ((uint64_t)tv.tv_sec * 1000 + (uint64_t)tv.tv_usec / 1000);
#endif
}

void print_array(ELE_TYPE arr[], int len)
{
	int i;
	for (i = 0; i < len; i++)
		printf("%d ",arr[i]);
	printf("\n");
}

下一篇 排序算法从入门到精通之二---冒泡排序

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值