|
| 1 | +<p>Given two integers <code>left</code> and <code>right</code>, return <em>the <strong>count</strong> of numbers in the <strong>inclusive</strong> range </em><code>[left, right]</code><em> having a <strong>prime number of set bits</strong> in their binary representation</em>.</p> |
| 2 | + |
| 3 | +<p>Recall that the <strong>number of set bits</strong> an integer has is the number of <code>1</code>'s present when written in binary.</p> |
| 4 | + |
| 5 | +<ul> |
| 6 | + <li>For example, <code>21</code> written in binary is <code>10101</code>, which has <code>3</code> set bits.</li> |
| 7 | +</ul> |
| 8 | + |
| 9 | +<p> </p> |
| 10 | +<p><strong class="example">Example 1:</strong></p> |
| 11 | + |
| 12 | +<pre> |
| 13 | +<strong>Input:</strong> left = 6, right = 10 |
| 14 | +<strong>Output:</strong> 4 |
| 15 | +<strong>Explanation:</strong> |
| 16 | +6 -> 110 (2 set bits, 2 is prime) |
| 17 | +7 -> 111 (3 set bits, 3 is prime) |
| 18 | +8 -> 1000 (1 set bit, 1 is not prime) |
| 19 | +9 -> 1001 (2 set bits, 2 is prime) |
| 20 | +10 -> 1010 (2 set bits, 2 is prime) |
| 21 | +4 numbers have a prime number of set bits. |
| 22 | +</pre> |
| 23 | + |
| 24 | +<p><strong class="example">Example 2:</strong></p> |
| 25 | + |
| 26 | +<pre> |
| 27 | +<strong>Input:</strong> left = 10, right = 15 |
| 28 | +<strong>Output:</strong> 5 |
| 29 | +<strong>Explanation:</strong> |
| 30 | +10 -> 1010 (2 set bits, 2 is prime) |
| 31 | +11 -> 1011 (3 set bits, 3 is prime) |
| 32 | +12 -> 1100 (2 set bits, 2 is prime) |
| 33 | +13 -> 1101 (3 set bits, 3 is prime) |
| 34 | +14 -> 1110 (3 set bits, 3 is prime) |
| 35 | +15 -> 1111 (4 set bits, 4 is not prime) |
| 36 | +5 numbers have a prime number of set bits. |
| 37 | +</pre> |
| 38 | + |
| 39 | +<p> </p> |
| 40 | +<p><strong>Constraints:</strong></p> |
| 41 | + |
| 42 | +<ul> |
| 43 | + <li><code>1 <= left <= right <= 10<sup>6</sup></code></li> |
| 44 | + <li><code>0 <= right - left <= 10<sup>4</sup></code></li> |
| 45 | +</ul> |
0 commit comments