华为OD机试统一考试D卷C卷 - 字符串摘要 py

题目描述

给定一个字符串的摘要算法,请输出给定字符串的摘要值

  1. 去除字符串中非字母的符号。
  2. 如果出现连续字符(不区分大小写) ,则输出:该字符 (小写) + 连续出现的次数。
  3. 如果是非连续的字符(不区分大小写),则输出:该字符(小写) + 该字母之后字符串中出现的该字符的次数
  4. 对按照以上方式表示后的字符串进行排序:字母和紧随的数字作为一组进行排序,数字大的在前,数字相同的,则按字母进行排序,字母小的在前。

输入描述

一行字符串,长度为[1,200]

输出描述

摘要字符串

用例1

输入

aabbcc

输出

a2b2c2

用例2

输入

bAaAcBb

输出

a3b2b2c0

说明

bAaAcBb:

第一个b非连续字母,该字母之后字符串中还出现了2次(最后的两个Bb) ,所以输出b2

a连续出现3次,输出a3,

c非连续,该字母之后字符串再没有出现过c,输出c0

Bb连续2次,输出b2

对b2a3c0b2进行排序,最终输出a3b2b2c0

Python

import sys

# 统计每个字符出现的次数
charCount = [0] * 128  # ASCII 码表中共有 128 个字符
sb = []  # 用于存储去除非字母的符号后的字符串
input = sys.stdin.readline().strip().lower()  # 将输入的字符串转换为小写
for c in input:
    if 'a' <= c <= 'z': 

剩余60%内容,订阅专栏后可继续查看/也可单篇购买

2024华为OD机试题库D卷 文章被收录于专栏

本专栏给大家提供了华为2024最新华为OD(D)卷的题目汇总。华为OD机试刷题记录机考算法题库,帮助你上岸华为。提供C++/Java、JavaScript、Python四种语言的解法。

全部评论
string = input() string = string.lower() lst = [] dic = {} cur = None cur_l = 0 for ch in string: if not ch.isalpha(): continue if cur is None: cur = ch cur_l = 1 continue if cur == ch: cur_l += 1 else: if cur in dic: dic[cur] += cur_l if cur_l == 1: dic[cur] = 0 else: lst.append((cur, cur_l)) cur = ch cur_l = 1 if cur in dic: dic[cur] += cur_l if cur_l == 1: dic[cur] = 0 else: lst.append((cur, cur_l)) for k, v in dic.items(): lst.append((k, v)) lst.sort(key=lambda x: (-x[1], x[0])) ans = "".join(f"{x[0]}{x[1]}" for x in lst) print(ans)
点赞
送花
回复 分享
发布于 07-04 16:56 贵州

相关推荐

点赞 收藏 评论
分享
牛客网
牛客企业服务