12556: 编码字符串
strings, http://cs101.openjudge.cn/practice/12556
在数据压缩中,一个常用的方法是行程长度编码压缩。对于一个待压缩的字符串,我们可以依次记录每个字符及重复的次数。例如,待压缩的字符串为"aaabbbbcbb",压缩结果为(a,3)(b,4)(c,1)(b,2)。这种压缩对于相邻数据重复较多的情况有效,如果重复状况较少,则压缩的效率较低。
现要求根据输入的字符串,首先将字符串中所有大写字母转化为小写字母,然后将字符串进行压缩。
输入
一个字符串,长度大于0,且不超过1000,全部由大写或小写字母组成。
输出
输出为编码之后的字符串,形式为:(a,3)(b,4)(c,1)(d,2),即每对括号内分别为小写字符及重复的次数,不含任何空格。
样例输入
aAABBbBCCCaaaaa样例输出
(a,3)(b,4)(c,3)(a,5)来源:cs10116 final exam
思路:遍历,如果当前字符和前一个一样,加一,否则换成新字符,旧的加到输出里,注意最后一次要加上。
python
sentence = input().lower()
list = []
pre = sentence[0]
count = 1
for i in range(1, len(sentence)):
if sentence[i] != pre:
list.append('(' + pre + ',' + str(count) + ')')
pre = sentence[i]
count = 1
else:
count += 1
list.append('(' + pre + ',' + str(count) + ')')
print(''.join(list))2020fall-cs101,李思哲
思路:双指针做法,d记录头c记录尾然后做差即可得到长度(重复次数),向输出的列表中直接添加格式化的字符串即可满足输出要求。
python
# 2020fall-cs101, Sizhe Li.
# tow pointers
a = list(input().lower()) + ["0"]
c,d = 0,-1
ans = []
for i in range(1, len(a)):
if a[i] != a[i-1]:
c = i - 1
ans.append("(%s,%d)"%(a[i-1], c-d))
d = c
print("".join(ans))