用c语言处理传感器信息,求省时的C语言传感器数据排序方法

LSD是比较好的。

#include

#define Max_ 10      //数组个数

#define RADIX_10 10    //整形排序

#define KEYNUM_31 10     //关键字个数,这里为整形位数

// 打印结果

void Show(int  arr[], int n)

{

int i;

for ( i=0; i

printf("%d  ", arr[i]);

printf("\n");

}

// 找到num的从低到高的第pos位的数据

int GetNumInPos(int num,int pos)

{

int temp = 1;

for (int i = 0; i < pos - 1; i++)

temp *= 10;

return (num / temp) % 10;

}

//基数排序  pDataArray 无序数组;iDataNum为无序数据个数

void RadixSort(int* pDataArray, int iDataNum)

{

int *radixArrays[RADIX_10];    //分别为0~9的序列空间

for (int i = 0; i < 10; i++)

{

radixArrays[i] = (int *)malloc(sizeof(int) * (iDataNum + 1));

radixArrays[i][0] = 0;    //index为0处记录这组数据的个数

}

for (int pos = 1; pos <= KEYNUM_31; pos++)    //从个位开始到31位

{

for (int i = 0; i < iDataNum; i++)    //分配过程

{

int num = GetNumInPos(pDataArray[i], pos);

int index = ++radixArrays[num][0];

radixArrays[num][index] = pDataArray[i];

}

for (int i = 0, j =0; i < RADIX_10; i++)    //收集

{

for (int k = 1; k <= radixArrays[i][0]; k++)

pDataArray[j++] = radixArrays[i][k];

radixArrays[i][0] = 0;    //复位

}

}

}

int main()

{   //测试数据

int arr_test[Max_] = { 8, 4, 2, 3, 5, 1, 6, 9, 0, 7 };

//排序前数组序列

Show( arr_test, Max_ );

RadixSort( arr_test, Max_);

//排序后数组序列

Show( arr_test, Max_ );

return 0;

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值