当前位置: 首页 > article >正文

蓝桥杯3. 压缩字符串

题目描述

实现一个算法来压缩一个字符串。压缩的要求如下:

  1. 需要判断压缩能不能节省空间,仅在压缩后字符串比原字符串长度更短时进行压缩。

  2. 压缩的格式是将连续相同字符替换为字符 + 数字形式,例如 "AAABCCDDDD" 变为 "A3BC2D4"。

输入描述

输入一行字符串,长度不超过 500.

输出描述

输出一行。若输入的字符串可压缩,则输出压缩后的字符串,否则输出 NO

输入输出样例

示例

输入

AAABCCDDDD

输出

A3BC2D4
import os
import sys
a=input()
dic=[]#创建一个字典
num=-1#设置一个num
for i in a:#遍历a中的元素
    if num == -1:#如果num等于-1
        dic.append({i:1})#则在字典中添加一个'元素':1,将这个元素为一个插进去
        num += 1#让num+1变成0
    else:
        if i in dic[num]:#又倒回去遍历a中元素,这时候num不等于-1了,如果这个元素在字典中
            dic[num][i]+=1#就让字典中的这个元素的后面值+1
        else:
            num += 1#如果下个元素不在字典中
            dic.append({i:1})#则再插入一个'元素':1进去
b=''#创建一个空字符串用于联合输出
for j in dic:#上面已经插入完了,现在遍历字典
    temp=list(j.items())[0]
    #print(list(j.items())) 这个意思是提取出第j项的字典放入list中
    #print(temp) 这个意思是选择第0项就是取出了('元素',x)
    if temp[1]>1:#如果元素数量大于1
        b+=temp[0]+str(temp[1])#则将第0项和第1项拼起来,注意第1项要转换为str因为b=''
    else:
        b+=temp[0]#b=b+temp[0]
if len(b)<len(a):
    print(b)
else:
    print('NO')

 


http://www.kler.cn/a/306222.html

相关文章:

  • Python Plotly 库使用教程
  • 排序算法 -快速排序
  • 微服务day08
  • 蓝队知识浅谈(上)
  • RabbitMQ高效的消息队列中间件原理及实践
  • LeetCode【0033】搜索旋转排序数组
  • 掌握远程管理的艺术:揭秘Python的pywinrm库
  • 【OJ刷题】双指针问题3
  • 通义灵码在Visual Studio上
  • spring-TransactionTemplate 编程式事务
  • C#笔记10 Thread类怎么终止(Abort)和阻止(Join)线程
  • SQLite的入门级项目学习记录(四)
  • [项目][WebServer][Task]详细讲解
  • python绘制3d建筑
  • flask-sqlalchemy的模型类两个表,既有一对一又有一对多的情况时,解决方法
  • SAP HCM HR_ABS_ATT_TIMES_AT_ENTRY 跨夜班不生效问题
  • 【MyBatis精讲】从入门到精通的详细指南:简化Java持久层操作的艺术
  • 开源 AI 智能名片小程序:开启内容营销新境界
  • Harmony Next 文件命令操作(发送、读取、媒体文件查询)
  • 【最佳实践】配置类封装-Async异步注解以及自定义线程池
  • 对操作系统(OS)管理和进程的理解
  • 28 线性表 · 栈
  • golang的GC(三色标记法+混合写屏障)学习笔记
  • 第一篇---滑动窗口最大值、前 K 个高频元素
  • 初识爬虫2
  • Linux删除SSH生成的密钥对