G'day Nick,

Nick Hibma <n_hi...@skylink.it> wrote:
> 
> Does anyone know an inexpensive algorithm (O(1)) to go from
> an number to the next (lower or higher) power of two.
> 
> 1                     -> 1
> 2,3                   -> 2
> 4,5,6,7                       -> 4
> 8,9,10,11,12,13,14,15 -> 8
> etc.
> 
> So %1101 should become either %10000 or %1000.

a bitwise shift left (to higher) or right (to lower) before or
after masking out all but the most significant bit in the number.

You just need to know how many bits to mask based on where the
most significant bit is ;]

I was tempted to throw something together but its late, and the
idea should be enough to go on ...

Cheers

Leigh
-- 
| "By the time they had diminished | Leigh Hart, <h...@dotat.com> |
|  from 50 to 8, the other dwarves | CCNA - http://www.cisco.com/ |
|  began to suspect 'Hungry' ..."  | GPO Box 487 Adelaide SA 5001 |
|   -- Gary Larson, "The Far Side" |  http://www.dotat.com/hart/  |


To Unsubscribe: send mail to majord...@freebsd.org
with "unsubscribe freebsd-hackers" in the body of the message

Reply via email to