久久久久久久999_99精品久久精品一区二区爱城_成人欧美一区二区三区在线播放_国产精品日本一区二区不卡视频_国产午夜视频_欧美精品在线观看免费

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 2127|回復(fù): 4
收起左側(cè)

求省時的C語言傳感器數(shù)據(jù)排序方法

[復(fù)制鏈接]
ID:318095 發(fā)表于 2019-4-1 11:48 | 顯示全部樓層 |閱讀模式
傳感器測量數(shù)據(jù)進行排序中值取平均,數(shù)據(jù)跟上位機通信時一直有延時感覺可能是排序時間過長,求一個省時的排序方法。
我自己試過兩種,大神有沒有其他的方法
第一種冒泡法
void sequence(float a[],int n)    //從小到大排序
{
  int i=0;
  int j=0;
  float temp=0;
  for(i=0;i<n-1;i++)
  {
    for(j=i+1;j<n;j++)
        {
          if(a[i]>a[j])
          {
            temp=a[i];
                a[i]=a[j];
                a[j]=temp;
          }
        }
  }
}  
第二種希爾排序
void ShellSort(int arr[], int length)
{
        int increasement = length;
        int ii,ij,ik;
        do
        {
                // 確定分組的增量
                increasement = increasement / 3 + 1;
                for (ii = 0; ii < increasement; ii++)
                {
                        for (ij = ii + increasement; ij < length; ij += increasement)
                        {
                                if (arr[ij] < arr[ij - increasement])
                                {
                                        int temp = arr[ij];
                                        for (ik = ij - increasement; ik >= 0 && temp < arr[ik]; ik -= increasement)
                                        {
                                                arr[ik + increasement] = arr[ik];
                                        }
                                        arr[ik + increasement] = temp;
                                }
                        }
                }
        } while (increasement > 1);
}

回復(fù)

使用道具 舉報

ID:158375 發(fā)表于 2019-4-1 12:45 | 顯示全部樓層
你是要求排序?還是要求區(qū)平均?
要想快:提高單片機的時鐘!
回復(fù)

使用道具 舉報

ID:277550 發(fā)表于 2019-4-1 13:14 | 顯示全部樓層
回復(fù)

使用道具 舉報

ID:505820 發(fā)表于 2019-4-6 17:12 | 顯示全部樓層
LSD是比較好的。
#include<stdio.h>

#define Max_ 10      //數(shù)組個數(shù)
#define RADIX_10 10    //整形排序
#define KEYNUM_31 10     //關(guān)鍵字個數(shù),這里為整形位數(shù)

// 打印結(jié)果
void Show(int  arr[], int n)
{
    int i;
    for ( i=0; i<n; i++ )
        printf("%d  ", arr[i]);
    printf("\n");
}

// 找到num的從低到高的第pos位的數(shù)據(jù)
int GetNumInPos(int num,int pos)
{
        int temp = 1;
        for (int i = 0; i < pos - 1; i++)
                temp *= 10;
   
        return (num / temp) % 10;
}


//基數(shù)排序  pDataArray 無序數(shù)組;iDataNum為無序數(shù)據(jù)個數(shù)
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處記錄這組數(shù)據(jù)的個數(shù)
        }
       
        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;    //復(fù)位
                }
        }
}

int main()
{   //測試數(shù)據(jù)
    int arr_test[Max_] = { 8, 4, 2, 3, 5, 1, 6, 9, 0, 7 };
    //排序前數(shù)組序列
    Show( arr_test, Max_ );
    RadixSort( arr_test, Max_);
    //排序后數(shù)組序列
    Show( arr_test, Max_ );
    return 0;
}
回復(fù)

使用道具 舉報

ID:366559 發(fā)表于 2019-4-7 12:01 | 顯示全部樓層
在單片機可以處理的數(shù)據(jù)量下,希爾排序一般都比歸并要快,因為后者需要遞歸調(diào)用
在更小的數(shù)據(jù)量下,冒泡和插入比希爾快
關(guān)于希爾排序的序列,自行百度
回復(fù)

使用道具 舉報

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規(guī)則

手機版|小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術(shù)交流QQ群281945664

Powered by 單片機教程網(wǎng)

快速回復(fù) 返回頂部 返回列表
主站蜘蛛池模板: 欧美乱操 | 精品影院 | 九九色九九 | 国产四虎 | 亚洲精品99 | 欧美寡妇偷汉性猛交 | 成人一区二区三区在线观看 | 日韩乱码一二三 | 国产精品亚洲综合 | 日韩在线中文 | 免费一级做a爰片久久毛片潮喷 | 精品久久一区 | 日屁视频 | 97国产超碰 | 国产做a爱免费视频 | 久在线| 色免费看| 福利视频网| 欧美日一区二区 | 青青青伊人| 亚洲人成人一区二区在线观看 | 中文字幕高清免费日韩视频在线 | 久久综合伊人 | 亚洲欧美中文日韩在线v日本 | 99pao成人国产永久免费视频 | 久久成人一区 | 久久免费观看一级毛片 | 在线国产一区 | 国产成人精品在线 | aaaaaa大片免费看最大的 | 99精品国产一区二区三区 | 日韩av在线一区 | 亚洲欧美日韩中文在线 | 国产精品一区二区欧美黑人喷潮水 | 欧美黑人一区二区三区 | 久草视频观看 | 亚洲成人自拍 | 午夜欧美一区二区三区在线播放 | 99精品久久久国产一区二区三 | 亚洲国产精品久久久 | 国产精品一区二 |