Love丶FFC's Blog

PAT乙级:1078 字符串压缩与解压

2020-04-10 12:58:01
阅读:7217   •   评论:151
标签:,

文本压缩有很多种方法,这里我们只考虑最简单的一种:把由相同字符组成的一个连续的片段用这个字符和片段中含有这个字符的个数来表示。例如 ccccc 就用 5c 来表示。如果字符没有重复,就原样输出。例如 aba 压缩后仍然是 aba

解压方法就是反过来,把形如 5c 这样的表示恢复为 ccccc

本题需要你根据压缩或解压的要求,对给定字符串进行处理。这里我们简单地假设原始字符串是完全由英文字母和空格组成的非空字符串。

输入格式:

输入第一行给出一个字符,如果是 C 就表示下面的字符串需要被压缩;如果是 D 就表示下面的字符串需要被解压。第二行给出需要被压缩或解压的不超过 1000 个字符的字符串,以回车结尾。题目保证字符重复个数在整型范围内,且输出文件不超过 1MB。

输出格式:

根据要求压缩或解压字符串,并在一行中输出结果。

输入样例 1:

C
TTTTThhiiiis isssss a   tesssst CAaaa as

输出样例 1:

5T2h4is i5s a3 te4st CA3a as

输入样例 2:

D
5T2h4is i5s a3 te4st CA3a as10Z

输出样例 2:

TTTTThhiiiis isssss a   tesssst CAaaa asZZZZZZZZZZ

编程语言:Python

解题思想:

1.无论压缩还是解压,都需要使用字符串拼接,对于判断的情况都是每一位与下一位进行

2.对于压缩,重点在于判断字符连续相同的情况并计数,同时对最后两个字符进行单独判断

3.对于解压,重点在于判断字符是数字还是字母(空格),同时需要使用while循环进行循环后移

时间复杂度:O(NlogN)

代码如下:

  1. Choose = input()
  2. String = input()
  3.  
  4. NewString = ""
  5. if Choose == 'C': # 压缩
  6. Count = 1 # 字符连续相同的个数
  7. for i in range(len(String) - 1): # 判断前n-1个字符的情况,最后一个字符需要单独判断,否则会下标越界
  8. if String[i] == String[i + 1]: # 下一位字符相同
  9. Count += 1
  10. else: # 下一位字符不同
  11. if Count == 1: # 该位字符没有连续出现
  12. NewString += String[i]
  13. else: # 改为字符连续出现过Count次
  14. NewString += str(Count) + String[i] # 拼接字符串
  15. Count = 1 # 重新统计
  16. if String[len(String) - 2] != String[len(String) - 1]: # 最后两位字符不同
  17. NewString += String[len(String) - 1]
  18. else: # 最后两位字符相同
  19. NewString += str(Count) + String[len(String) - 1]
  20. elif Choose == 'D': # 解压
  21. i = 0
  22. Count = ''
  23. while i < len(String): # 遍历字符串
  24. if String[i].isnumeric(): # 该字符是数字
  25. Count += String[i]
  26. for j in range(i + 1, len(String)): # 遍历剩余字符串
  27. if String[j].isnumeric(): # 下一字符仍是数字
  28. Count += String[j] # 将该数字拼接,例如1235A,需要理解为1235个A
  29. else: # 下一字符不再是数字
  30. NewString += int(Count) * String[j] # 将1235A进行1235*A运算
  31. i = j + 1 # 循环右移,中间部分不再判断
  32. break
  33. else: # 该字符是字母(空格),单独拼接
  34. NewString += String[i]
  35. i += 1
  36. Count = ''
  37. print(NewString)

评论板

共有 151 条评论

  1. Abupguele

    It was claimed that Flo Jo was using performance enhancing drugs during her career, despite the fact that she had never tested positive lasix online no prescription

  2. louis vuitton outlet online

    I just wanted to thank you for the fast service. or a they look great. I received them a day earlier than expected. cherish the I will definitely continue to buy from this site. in any event I will recommend this site to my friends. Thanks!
    louis vuitton outlet online https://www.bestlouisvuittonoutlet.com/

  3. cheap louis vuitton bags

    I just wanted to thank you for the fast service. as they look great. I received them a day earlier than expected. similar to I will definitely continue to buy from this site. in either case I will recommend this site to my friends. Thanks!
    cheap louis vuitton bags https://www.louisvuittonsoutletstore.com/

  4. Knitant

    The people baroreceptor lower blood pressure behind the curtains hurried over buying generic cialis online safe

  5. authentic cheap jordans

    Read reviews and was a little hesitant since I had already inputted my order. or simply but thank god, I had no issues. for instance received item in a timely matter, they are in new condition. you decide so happy I made the purchase. Will be definitely be purchasing again.
    authentic cheap jordans https://www.cheapretrojordan.com/

  6. cheap jordans online

    Read reviews and was a little hesitant since I had already inputted my order. or perhaps even but thank god, I had no issues. similar to the reduction received item in a timely matter, they are in new condition. no matter what so happy I made the purchase. Will be definitely be purchasing again.
    cheap jordans online https://www.realcheapjordan.com/

  7. cheap jordans

    Read reviews and was a little hesitant since I had already inputted my order. to but thank god, I had no issues. choose the received item in a timely matter, they are in new condition. you decide so happy I made the purchase. Will be definitely be purchasing again.
    cheap jordans https://www.realjordansshoes.com/

  8. cheap louis vuitton bags

    Read reviews and was a little hesitant since I had already inputted my order. potentially but thank god, I had no issues. as good as the received item in a timely matter, they are in new condition. you ultimately choose so happy I made the purchase. Will be definitely be purchasing again.
    cheap louis vuitton bags https://www.louisvuittonsoutletonline.com/

  9. authentic cheap jordans

    Read reviews and was a little hesitant since I had already inputted my order. along with but thank god, I had no issues. simillar to the received item in a timely matter, they are in new condition. in any event so happy I made the purchase. Will be definitely be purchasing again.
    authentic cheap jordans https://www.realjordansretro.com/

  10. https://cse.google.so/url?q=https://www.topchristianlouboutinoutlet.com/

    |Every woman should at least have a few key items in her closet. It is important to have jeans hemmed for sneakers and some for heels, then a couple pairs of darker, dressier slacks. Let’s not forget the mainstay for every woman, the little black dress.

  11. https://images.google.com.gi/url?sa=t&url=https://www.topfakeyeezys.com/

    {Casual up-dos are a good way to pick up the hair from your shoulders. Long, loose hair can get in the way during work or play. When you’re out of time, put your hair up in a bun!

  12. invoimi

    Results were expressed as mean and standard deviation of the mean propecia fast delivery

  13. Pipe fittings supplier

    يتضح التزام إيليت بايب Elite Pipe بإرضاء العملاء في جداول التسليم الفوري وخدمة ما بعد البيع الاستثنائية.

  14. elitepipeiraq.com

    ElitePipe Plastic Factory – Your One-Stop Piping Solution in Iraq! 🌍 🏭 Elite Pipe Plastic Factory takes pride in being a trusted manufacturer and supplier of superior plastic piping solutions in Iraq. With our comprehensive product range and unwavering commitment to quality, we are your go-to source for all your piping needs. ✅ HDPE, UPVC, and LDPE Pipes: Our high-quality High-Density Polyethylene (HDPE), Unplasticized Polyvinyl Chloride (UPVC), and Low-Density Polyethylene (LDPE) pipes are engineered to provide exceptional durability, excellent flow characteristics, and resistance to corrosion. Whether it’s water supply, irrigation, or industrial applications, our pipes deliver unmatched performance. 🔩 Butt Welding Machines & Electrofusion Welding EF Machines: We offer state-of-the-art Butt Welding Machines and Electrofusion Welding EF Machines that ensure precise and efficient joining of pipes. These cutting-edge machines guarantee strong and leak-proof connections, meeting the highest industry standards. 🔌 Fittings & Electrofusion Fittings: Complementing our pipe offerings, we provide a wide range of fittings and electrofusion fittings. These products are designed to facilitate seamless installation, enabling reliable connections and optimal system performance. 🌾 Agriculture Pipes: Elite Pipe Plastic Factory understands the importance of efficient irrigation systems in agriculture. Our specially designed agriculture pipes deliver water efficiently to enhance crop growth and maximize yield. Count on us for durable and reliable solutions for your agricultural needs. 🤝 We are committed to delivering products that exceed your expectations. With our superior quality, advanced technology, and dedicated customer service, Elite Pipe Plastic Factory is the trusted partner you can rely on. 📞 Contact us today to discuss your project requirements and experience the excellence of Elite Pipe Plastic Factory! Let us be your preferred choice for top-notch plastic piping solutions in Iraq. 🚀

  15. 6 pvc pipe 20

    This was beautiful Admin. Thank you for your reflections.

--------查看该分类下最新文章--------
^
新版博客正在完善中!域名:http://www.loveffc:8080,点击跳转,完全移植后将去除端口号。

Copyright © 2018 - 2021 FFC的小站 - 滇 ICP 备 18010780 号 - 1

- Powered by WordPress & AliYun · Theme by FFC -

- Environment by Windows & XAMPP · Designed by WebStorm & VSCode -

已运行:

访问量:491826