华为OD机试-字符串分割

题目描述

给定一个非空字符串S,其被N个‘-’分隔成N+1的子串,给定正整数K,要求除第一个子串外,其余的子串每K个字符组成新的子串,并用‘-’分隔。对于新组成的每一个子串,如果它含有的小写字母比大写字母多,则将这个子串的所有大写字母转换为小写字母;反之,如果它含有的大写字母比小写字母多,则将这个子串的所有小写字母转换为大写字母;大小写字母的数量相等时,不做转换。
输入描述:
输入为两行,第一行为参数K,第二行为字符串S。
输出描述:
输出转换后的字符串。
示例1
输入
3
12abc-abCABc-4aB@
输出
12abc-abc-ABC-4aB-@
说明
子串为12abc、abCABc、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@

代码实现

# coding:utf-8
class Solution:
    def stringSplit(self, k, s):
        begin = 0
        end = 0
        # 遍历字符串,遇到第一个分隔符的时候跳出,将第一个子串存下来,不需要做大小写转换
        for i in s:
            if i == '-':
                break
            else:
                end += 1
        res = s[begin:end]
        begin = end + 1

        # 从第二个子串开始判断
        while begin < len(s):
            tmp = ''
            lower = 0
            linefix = 0
            # 每K个字符串作为一个新的子串长度
            for i in range(k):
                while begin + i + linefix <= len(s) - 1 and s[begin + i + linefix] == '-':  # 遇到分隔符,直接跳过不处理,分隔符计数器+1
                    linefix += 1
                if begin + i + linefix > len(s) - 1:  # 超出原字符串长度,跳出
                    break
                if s[begin + i + linefix].islower():  # 当前字符为小写,则小写计数器加1
                    lower += 1
                elif s[begin + i + linefix].isupper():  # 当前字符为大写,则小写计数器减1
                    lower -= 1
                tmp = tmp + s[begin + i + linefix]

            # 小写字符多则全部转小写,反之,转大写
            if lower > 0:
                res = res + '-' + tmp.lower()
            if lower < 0:
                res = res + '-' + tmp.upper()
            if lower == 0:
                res = res + '-' + tmp
            begin = begin + k + linefix
        return res


if __name__ == '__main__':
    k = input("K:")
    s = input("s:")
    solution = Solution()
    print(solution.stringSplit(int(k), s))

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值