# 题目描述 # 给定一个完全由数字字符‘0’,‘1’,‘2’,…,‘9’构成的字符串 str, # 请写出 str 的 p 型编码串。 # 例如:字符串 122344111 可被描述为" 1个1、2个2 、1个3 、2个4 、3个1 ", # 因此我们说 122344111 的p型编码串为 1122132431 ; # 类似的道理,编码串 101可以用来描述 1111111111; # 00000000000 可描述为" 11 个 0 ",因此它的p 型编码串即为 110; # 100200300 可描述为" 1 个 1、 2个 0、1 个 2 、2 个 0 、1 个 3 、2 个0 ", # 因此它的 p型编码串为112012201320。 # # 输入 # 字符串 str。 # # 输出 # 输出该字符串对应的 p 型编码串。 # # 输入样例 # # 122344111 # 输出样例 # # 1122132431
str = "122344111"
# 加一个空格在最后才可以比较最后1个数字
str = str + " "
count = 1
i = 0
while i < len(str)-1:
if str[i] == str[i + 1]:
count = count + 1
else:
print(count, end='')
print(str[i], end='')
count = 1
i = i+1
比较坑的点:
- 在字符串后面加个空格,不然最后一个数字没办法打印
- 使用for循环没有while循环计数