|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
题目:请按照以下规则整理一个给定的字符串 s。
一个整理好的字符串中,两个相邻字符 s[j] 和 s[j+1],其中 0 <= j <= s.length - 2,要满足如下条件:
若 s[j] 是小写字符,则 s[j+1] 不可以是相同的大写字符
若 s[j] 是大写字符,则 s[j+1] 不可以是相同的小写字符
如果 s[j] 和 s[j+1] 满足以上两个条件,则将它们一并删除
举例:
整理前:"FishCcCode"
整理后:"FishCcCode" -> "FishCode")
整理前:"AbBaACc"
整理后:"AbBaACc" -> "AaACc" -> "AaA" -> "A"
整理前:"AABaAbCc"
整理后:"AABaAbCc" -> "AABbCc" -> "AACc" -> "AA"
请按要求整理好字符串,并将结果打印到屏幕上。
提示(小甲鱼不想限制大家的思路,如果想看的话,请使用鼠标刮开叭~):将字符串逐个读取,整理后放到一个列表中,最后将列表中的元素挨个打印即可。
- s = input("请输入一个字符串:")
-
- res = []
- for each in s:
- if res and res[-1].lower() == each.lower() and res[-1] != each:
- res.pop()
- else:
- res.append(each)
-
- for each in res:
- print(each, end='')
复制代码
这个代码看不懂哎,咋做到 比如出现Aa的时候把他俩都删除啊!!!一头雾水
以"CAb“为例
第一次循环
res 为 []
each 为 "C"
if 为 False
res 为 ["C"]
第二次循环
res 为 ["C"]
each 为 "A"
if 为 False
res 为 ["C", "A"]
第三次循环
res 为 ["C", "A"]
each 为 "a"
if 为 True
res弹出"A"
res 为 ["C"]
|
|