昨天看到朋友圈里面有一个朋友发了一个圈,感觉11111有点特别,于是有个想法把他的11111变成非特别数字,顺便做个练习
代码.png1,代码如下
结果.png2,结果如下:
代码.png3,在网上找了一段比我高级很多的算法,可以计算不同进制的和:
结果.png4,结果如下:
5,全部代码如下:
str= "11111"
length = len(str)
i = 0
sum=0
while i<length:
Int =int(str[i])
i +=1
sum=sum+Int
print("和为:%d"%sum)
print("-"*30)
str= "123456789"
length = len(str)
i = 0
sum=0
while i<length:
Int =int(str[i])
i +=1
sum=sum+Int
print("和为:%d"%sum)
print("-"*30)
str= "123456789123456789"
length = len(str)
i = 0
sum=0
while i<length:
Int =int(str[i])
i +=1
sum=sum+Int
print("和为:%d"%sum)
#####别人的代码
print("#"*30)
print("-"*12 + "别人的代码的结果" + "-"*12)
def sum_str(str1):
len1=len(str1) #首先将字符串str1的长度赋值给len1
sum = n = 0 #建立一个值为0的空变量sun #建立一个值为0的空变量n
for i in range(len1): #用i来遍历字符串的长度
if 49 <= ord(str1[i]) <= 57: #判断字符ascii码是否在数字ascii值范围内
n = n * 10 #n *= 10
n = int(str1[i]) + n #n += int(str1[i])
else:
sum = n + sum #sum += n
n = 0
# 上面6行代码的意思是从0下标开始,遍历字符串,如果是数字,用n加上其数字,
#执行逻辑是,碰见一个数字,用n加上,如果下一个还是数字,就将上一个数字乘10加这个数字,依次循环
#比如:连续数字df123asd = ((1*10+2)*10)+3
#如果不是数字,就将n值加到变量sum中,保存,并且将n重新赋值为0,再次进入for循环,(sun只在碰见字母的时候出现,把数字之前的数字的值收集起来)
# 下次再碰到数字(满足if条件),循环(if)条件下面的逻辑
sum = n +sum
print(sum)
str1 = "b532h2x3c4b5"
sum_str(str1) #调用函数
网友评论