Quickly find whether a value is present in a C array?

前端 未结 15 1308
灰色年华
灰色年华 2021-01-29 17:30

I have an embedded application with a time-critical ISR that needs to iterate through an array of size 256 (preferably 1024, but 256 is the minimum) and check if a value matches

15条回答
  •  故里飘歌
    2021-01-29 17:57

    There's a trick for optimizing it (I was asked this on a job-interview once):

    • If the last entry in the array holds the value that you're looking for, then return true
    • Write the value that you're looking for into the last entry in the array
    • Iterate the array until you encounter the value that you're looking for
    • If you've encountered it before the last entry in the array, then return true
    • Return false

    bool check(uint32_t theArray[], uint32_t compareVal)
    {
        uint32_t i;
        uint32_t x = theArray[SIZE-1];
        if (x == compareVal)
            return true;
        theArray[SIZE-1] = compareVal;
        for (i = 0; theArray[i] != compareVal; i++);
        theArray[SIZE-1] = x;
        return i != SIZE-1;
    }
    

    This yields one branch per iteration instead of two branches per iteration.


    UPDATE:

    If you're allowed to allocate the array to SIZE+1, then you can get rid of the "last entry swapping" part:

    bool check(uint32_t theArray[], uint32_t compareVal)
    {
        uint32_t i;
        theArray[SIZE] = compareVal;
        for (i = 0; theArray[i] != compareVal; i++);
        return i != SIZE;
    }
    

    You can also get rid of the additional arithmetic embedded in theArray[i], using the following instead:

    bool check(uint32_t theArray[], uint32_t compareVal)
    {
        uint32_t *arrayPtr;
        theArray[SIZE] = compareVal;
        for (arrayPtr = theArray; *arrayPtr != compareVal; arrayPtr++);
        return arrayPtr != theArray+SIZE;
    }
    

    If the compiler doesn't already apply it, then this function will do so for sure. On the other hand, it might make it harder on the optimizer to unroll the loop, so you will have to verify that in the generated assembly code...

提交回复
热议问题