PAT 乙级 1057 数零壹 python

题目
在这里插入图片描述
思路
先判断是否为字母
再求和
通过迭代取余 计算0 1的数目

代码

alpha={'a':1,'b':2,'c':3,'d':4,'e':5,'f':6,'g':7,
       'h':8,'i':9,'j':10,'k':11,'l':12,'m':13,'n':14,
       'o':15,'p':16,'q':17,'r':18,'s':19,'t':20,'u':21,
       'v':22,'w':23,'x':24,'y':25,'z':16}
input_=input()

sum=0
for i in input_:
    if i =='\n':
        break
    if 'a'<=i<='z' or  'A'<=i<='Z':
        i=i.lower()
        sum=alpha[i]+sum

#q,r=divmod(sum,2)

zero_count = 0
one_count = 0

while(sum!=0):
    sum, r = divmod(sum, 2)
    if r==0:
        zero_count=zero_count+1
    else:
        one_count = one_count +1

# if sum!=0 and r==0:
#         zero_count=zero_count+1
# if sum != 0 and r == 1:
#         one_count = one_count +1

print(zero_count,one_count)
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值