Note that powers of 2 can be written in binary as
data:image/s3,"s3://crabby-images/23768/237683c2104d0008049017889882ae5c8f6f24d5" alt="2^0=1_2"
data:image/s3,"s3://crabby-images/f454b/f454bc13a11d5db762d75ea2fea583c773474266" alt="2^1=10_2"
data:image/s3,"s3://crabby-images/260be/260be44c93fa49ef1b28eb17234a01313b5889e6" alt="2^2=100_2"
and so on. Observe that
data:image/s3,"s3://crabby-images/93e74/93e74a4c3f26cd8c0d635e18ae4d070afb43b82e" alt="n+1"
digits are required to represent the
data:image/s3,"s3://crabby-images/484da/484dac6e965f4541b7d596aefc2ccbc309963bbd" alt="n"
-th power of 2 in binary.
Also observe that
data:image/s3,"s3://crabby-images/f6de9/f6de998eedc9591a896b6195b18f095d745e5f16" alt="\log_2(2^n)=n\log_22=n"
so we need only add 1 to the logarithm to find the number of binary digits needed to represent powers of 2. For any other number (non-power-of-2), we would need to round down the logarithm to the nearest integer, since for example,
data:image/s3,"s3://crabby-images/f286e/f286eb45ff83609cf5847150c2704bb1598846f4" alt="2_{10}=10_2\iff\log_2(2^1)=\log_22=1"
data:image/s3,"s3://crabby-images/bb8e8/bb8e896462fe8cbbac534bb1f18efae70d508d4c" alt="3_{10}=11_2\iff\log_23=1+(\text{some number between 0 and 1})"
data:image/s3,"s3://crabby-images/ee3d6/ee3d63141b1d4ed82a50ad93795e3fc9482adeb4" alt="4_{10}=100_2\iff\log_24=2"
That is, both 2 and 3 require only two binary digits, so we don't care about the decimal part of
data:image/s3,"s3://crabby-images/6b932/6b93258cd5f499c7419eb7131ad1145f5697335b" alt="\log_23"
. We only need the integer part,
data:image/s3,"s3://crabby-images/a9e48/a9e4848fc76c2fcae0ba14f9d556e5e0fa75d78c" alt="\lfloor\log_23\rfloor"
, then we add 1.
Now,
data:image/s3,"s3://crabby-images/24100/241001120331f9d8f045d9d21e6c49e1c6afd09f" alt="2^9=512"
, and 999 falls between these consecutive powers of 2. That means
data:image/s3,"s3://crabby-images/626f8/626f83075ce21e32c52511f235d1ed02c80a1ae6" alt="\log_2999=9+\text{(some number between 0 and 1})"
which means 999 requires
data:image/s3,"s3://crabby-images/87de2/87de2e09fcdfcbc50fd83e6b40728ea73032b694" alt="\lfloor\log_2999\rfloor+1=9+1=10"
binary digits.
Your question seems to ask how many binary digits in total you need to represent all of the numbers 0-999. That would depend on how you encode numbers that requires less than 10 digits, like 1. Do you simply write
data:image/s3,"s3://crabby-images/856ac/856ac914aa3a47aab37db23f89caa0af1aa945cc" alt="1_2"
? Or do you pad this number with 0s to get 10 digits, i.e.
data:image/s3,"s3://crabby-images/2972e/2972e1becf15142111c400d0db1a78e785a27840" alt="0000000001_2"
? In the latter case, the answer is obvious;
data:image/s3,"s3://crabby-images/51d45/51d459a595d54fde47813da8516fa20694c63c69" alt="1000\times10=10^4"
total binary digits are needed.
In the latter case, there's a bit more work involved, but really it's just a matter of finding how many number lie between successive powers of 2. For instance, 0 and 1 both require one digit, 2 and 3 require two, while 4-7 require three, while 8-15 require four, and so on.