描述
给定一个非空字符串S,其被N个‘-’分隔成N+1的子串,给定正整数K,要求除第一个子串外,其余的子串每K个字符组成新的子串,并用‘-’分隔。对于新组成的每一个子串,如果它含有的小写字母比大写字母多,则将这个子串的所有大写字母转换为小写字母;反之,如果它含有的大写字母比小写字母多,则将这个子串的所有小写字母转换为大写字母;大小写字母的数量相等时,不做转换。
输入描述:
输入为两行,第一行参数K,第二行为字符串S。
输出描述:
输出转换后的字符串
示例1
输入:
3
12abc-abCABc-4aB@
输出:
12abc-abc-ABC-4aB-@
说明: 子串为12abc、abC、ABc、4aB@,第一个子串保留,后面的子串每3个字符一组为abC、ABc、4aB、@,abC中小写字母较多,转换为abc,ABc中大写字母较多,转换为ABC,4aB中大小写字母都为1个,不做转换,@中没有字母,连起来即12abc-abc-ABC-4aB-@
示例2
输入:
12
12abc-abCABc-4aB@
输出:
12abc-abCABc4aB@
说明: 子串为12abc、abCABc、4aB@,第一个子串保留,后面的子串每12个字符一组为abCABc4aB@,这个子串中大小写字母都为4个,不做转换,连起来即12abc-abCABc4aB@
k = int(input("请输入k值:")) # 输入数字
s = str(input("请输入字符串:")) # 输入字符串
def new_str(k,s):
list_split = s.split("-") # 根据-分割字符串,生成列表
str_body = "".join(list_split[1::1]) # 取出除第一个外的其他字符串
n = len(str_body)//k # 计算分割次数
list_body = [] # 定义空表存放分割出的子串
for i in range(n+1): # 从0到分割次数+1循环
child = str_body[i*k:(i+1)*k] # 取出第一个子串
slow_num = sum([1 for letter in child if letter.islower()]) # 用循环计算小写字母数,每个小写字母,列表生成器生成一个1
upper_num = sum([1 for letter in child if letter.isupper()]) # 同上方法计算大写字母数
if slow_num > upper_num: # 判断大小写字母的多少,如果小写字母多
child = child.lower() # 子串全部小写,lower函数会生成一个新的字符串,需要把新串赋值给child
elif slow_num < upper_num: # 如果大写字母多
child = child.upper() # 大写子串
list_body.append(child) # 把生成的子串追加到列表
new_str = list_split[0] + "-" + "-".join(list_body) # 合并:头串+分隔符“-”,+用“-”分开的列表字符串
return new_str
print(new_str(k,s))