标题: 数组十六进制的排序 [打印本页]

作者: 1314love    时间: 2022-8-24 08:45
标题: 数组十六进制的排序
u8 code ErrorTab1[] =
{
0xFF,0x08,0x08,0x08,0xFF,0x0F,0x14,0x14,0x14,0x09,0xFF,0x00,0x03,0xFF,0x00,0x00,
0x03,0x03,0x04,0x04,0x03,0x00,0x00,0x00,0x00,

0x80,0x00,0x00,0x00,0x80,0x00,0x80,0x80,0x80,0x00,0x80,0x80,0x00,0x00,0x80,0x80,
0x00,0x00,0x80,0x80,0x00,0x00,0x00,0x00,0x00,
};

u8 code HELLOTab1[] =
{
0xFF,0x80, //1111 1111 1000 0000
0x08,0x00, //0000 1000 0000 0000
0x08,0x00,
0x08,0x00,
0xFF,0x80,
0x0F,0x00,
0x14,0x80,
0x14,0x80,
0x14,0x80,
0x09,0x00,
0xFF,0x80,
0x00,0x80,
0x03,0x00,
0xFF,0x00,
0x00,0x80,
0x00,0x80,
0x03,0x00,
0x03,0x00,
0x04,0x80,
0x04,0x80,
0x03,0x00,
0x00,0x00,
0x00,0x00,
0x00,0x00,
0x00,0x00,
};
请问有什么办法写个函数实现HELLOTab1[]这个函数的排序,刚开始是这个数组ErrorTab1[]的排列顺序?


作者: 飞云居士    时间: 2022-8-24 10:32
最简单的排序算法----“冒泡法”;还有二分法;还有。。。
作者: xianfajushi    时间: 2022-8-24 12:06
简单点冒泡程序用本数组即可,快一点用改进型三冒泡,不输给快排。
作者: coody_sz    时间: 2022-8-24 12:31
排序跟进制无关,冒泡算法即可。
作者: lkc8210    时间: 2022-8-24 13:31
初始数组的排列是
[A0,A1,A2...
B0,B1,B2...]

目标数组的排列是
[A0,B0,A1,B1...]
  1. void ArrangeArray(u8* Soc, u8* Tar, u8 Len)
  2. {
  3.         u8 i;
  4.         for(i=0;i<Len/2;i++)
  5.         {
  6.                 Soc[i*2]=Tar[i];
  7.                 Soc[i*2+1]=Tar[i+Len/2];
  8.         }
  9. }
复制代码




作者: 杰西Jesse    时间: 2022-8-24 16:04
可以用for数组点亮
作者: 1314love    时间: 2022-8-24 16:23
本帖最后由 1314love 于 2022-8-26 09:13 编辑

不是大到小或者小到大的排序
我是用这种,还有没有更加简便一点的

void hexsort(void)
{
        u8 i,j=0;
        for(i = 25;i < 50;i++)
        {
                temp[j++] = HelloTab1;
        }
        for(i = 48,j = 24;i >=0;i -= 2,j--)
        {
                led_deposit = HelloTab1[j];
        }
        for(i = 1, j = 0;i < 50 ;i += 2)
        {
                led_deposit = temp[j++];
        }
}

作者: Hephaestus    时间: 2022-8-24 18:10
既然是固定数组,为什么不排好序在写到程序里面???




欢迎光临 (http://www.51hei.com/bbs/) Powered by Discuz! X3.1