常用排序算法(C语言)

1.十大经典排序算法动图图解

https://blog.csdn.net/zhangshk_/article/details/82911093

2.希尔排序

//希尔排序Shell Sort

#include <stdio.h>
#include <stdlib.h>
void ShellSort(int a[], int length)
{
	int increment;
	int i,j;
	int temp;
	for(increment = length/2; increment > 0; increment /= 2) //第1个循环:用来控制步长,最后递减到1
	{
		// i从第step开始排列,应为插入排序的第一个元素
		// 可以先不动,从第二个开始排序
        printf("\n增量 increment = %d\n",increment);
		for(i = increment; i < length; i++)  //第2个循环:插入排序,增量到数组结束
		{

			temp = a[i];                                                    //i,i-increment是一组插入排序
			for(j = i - increment; j >= 0 && temp < a[j]; j -= increment)  //第3个循环:插入排序,j分组,将a[i]插入到组内前n个
			{
				a[j + increment] = a[j];
			}
			a[j + increment] = temp; //将第一个位置填上
            printf("循环外前数 j + increment = %d a[j + increment] =%d \n",j + increment,a[j + increment]);
		}
	}
}
 
int main()
{
	printf("==============希尔排序===============\n\n");
	int i, j;
	int a[] = {5, 18, 151, 138, 160, 63, 174, 169, 79, 200};	
	printf("待排序的序列是: \n");
	for(i = 0; i < 10; i++)
	{
		printf("%d ", a[i]);
	}
	ShellSort(a, 10);
	printf("\n排序后的序列是: \n");
	for(j = 0; j < 10; j++)
	{
		printf("%d ", a[j]);
	}
	printf("\n");
    while(1);
	return 0;
}
 

3.基数排序

/**
 * 基数排序:C 语言
 *
 * @author skywang
 * @date 2014/03/15
 */

#include <stdio.h>

// 数组长度
#define LENGTH(array) ( (sizeof(array)) / (sizeof(array[0])) )

/*
 * 获取数组a中最大值
 *
 * 参数说明:
 *     a -- 数组
 *     n -- 数组长度
 */
int get_max(int a[], int n)
{
    int i, max;

    max = a[0];
    for (i = 1; i < n; i++)
        if (a[i] > max)
            max = a[i];
    return max;
}

/*
 * 对数组按照"某个位数"进行排序(桶排序)
 *
 * 参数说明:
 *     a -- 数组
 *     n -- 数组长度
 *     exp -- 指数。对数组a按照该指数进行排序。
 *
 * 例如,对于数组a={50, 3, 542, 745, 2014, 154, 63, 616};
 *    (01) 当exp=1表示按照"个位"对数组a进行排序
 *    (02) 当exp=10表示按照"十位"对数组a进行排序
 *    (03) 当exp=100表示按照"百位"对数组a进行排序
 *    ...
 */
 //  1.基数出现次数统计 --> 2.次数累加,成为基数最大下标 --> 3.基数与位置对应关系数组,存入临时数组 -->下标减一
void count_sort(int a[], int n, int exp)
{
    int output[n];             // 存储"被排序数据"的临时数组
    int i, buckets[10] = {0};

    // 1.将数据出现的次数存储在buckets[]中
    for (i = 0; i < n; i++){
        buckets[ (a[i]/exp)%10 ]++;
        printf("(a[i]/exp)%10  = %d  buckets[ (a[i]/exp)%10 ] = %d \n",(a[i]/exp)%10 ,buckets[ (a[i]/exp)%10 ]);
    }

    // 2.更改buckets[i]。目的是让更改后的buckets[i]的值,是该数据在output[]中的位置。
    for (i = 1; i < 10; i++){
        buckets[i] += buckets[i - 1];
         printf("i = %d  buckets[i] = %d \n",i,buckets[i]);
    }
    // 3.将数据存储到临时数组output[]中
    for (i = n - 1; i >= 0; i--)
    {
        output[buckets[ (a[i]/exp)%10 ] - 1] = a[i];
        buckets[ (a[i]/exp)%10 ]--;
    }

    // 将排序好的数据赋值给a[]
    for (i = 0; i < n; i++)
        a[i] = output[i];
}

/*
 * 基数排序
 *
 * 参数说明:
 *     a -- 数组
 *     n -- 数组长度
 */
void radix_sort(int a[], int n)
{
    int exp;    // 指数。当对数组按各位进行排序时,exp=1;按十位进行排序时,exp=10;...
    int max = get_max(a, n);    // 数组a中的最大值

    // 从个位开始,对数组a按"指数"进行排序
    for (exp = 1; max/exp > 0; exp *= 10)
        count_sort(a, n, exp);
}

void main()
{
    int i;
    int a[] = {53, 3, 542, 748, 14, 214, 154, 63, 616};
    int ilen = LENGTH(a);

    printf("before sort:");
    for (i=0; i<ilen; i++)
        printf("%d ", a[i]);
    printf("\n");

    radix_sort(a, ilen);

    printf("after  sort:");
    for (i=0; i<ilen; i++)
        printf("%d ", a[i]);
        while(1);
    printf("\n");
}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值