Python二进制表示形式中设置位的素数
假设我们有两个整数L和R,我们必须找到在[L,R](含)范围内的二进制数形式的素数。
因此,如果输入像L=6和R=10,那么输出将是4,因为有4个数字6(110),7(111),9(1001),10(1010),都具有质数设置位数。
为了解决这个问题,我们将遵循以下步骤-
计数:=0
对于L到R范围内的j,执行
如果j的设置位计数在[2,3,5,7,11,13,17,19]中,则
数:=数+1
返回计数
让我们看下面的实现以更好地理解-
示例
class Solution: def countPrimeSetBits(self, L, R): def popcount(i): return bin(i)[2:].count('1') count = 0 for j in range(L,R+1): if popcount(j) in [2,3,5,7,11,13,17,19]: count +=1 return count ob = Solution() print(ob.countPrimeSetBits(6,10))
输入值
6,10
输出结果
4