kate 挑战:一个数组和零,将等效二进制值转换为整数

给定一个数组和零,将等效二进制值转换为整数。
例如:[0,0,0,1]被视为0001,它是1的二进制表示。

例子:

Testing: [0, 0, 0, 1] ==> 1
Testing: [0, 0, 1, 0] ==> 2
Testing: [0, 1, 0, 1] ==> 5
Testing: [1, 0, 0, 1] ==> 9
Testing: [0, 0, 1, 0] ==> 2
Testing: [0, 1, 1, 0] ==> 6
Testing: [1, 1, 1, 1] ==> 15
Testing: [1, 0, 1, 1] ==> 11
但是,阵列可以具有不同的长度,而不仅限于4

第一种

def binary_array_to_number(arr):
    a =""
    for i in arr:
        b = str(i)
        a += b					  				#字符串相加
    return int(a,2)								#对字符进行二进制转十进制
print(binary_array_to_number([0,1,0,1]))		#举例
#(输出)5

第二种

def binary_array_to_number(arr):
  return int("".join(map(str, arr)), 2)			
  
#利用map函数,直接对arr 列表中的每个元素进行str()处理,然后join添加到""里面
#最后进行二进制转化为十进制

print(binary_array_to_number([0,1,0,1]))		#举例
#(输出)5
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值