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

解决leetcode第3614题用特殊操作处理字符串II

3614.用特殊操作处理字符串II

难度:困难

问题描述:

给你一个字符串s,由小写英文字母和特殊字符:'*'、'#'和'%'组成。

同时给你一个整数k。

请根据以下规则从左到右处理s中每个字符,构造一个新的字符串result:

如果字符是小写英文字母,则将其添加到result中。

字符'*'会删除result中的最后一个字符(如果存在)。

字符'#'会复制当前的result并追加到其自身后面。

字符'%'会反转当前的result。

返回最终字符串result中第k个字符(下标从0开始)。如果k超出result的下标索引范围,则返回'.'。

示例1:

输入:s="a#b%*",k=1

输出:"a"

解释:

最终的result是"ba"。下标为k=1的字符是'a'。

示例2:

输入:s="cd%#*#",k=3

输出:"d"

解释:

最终的result是"dcddcd"。下标为k=3的字符是'd'。

示例3:

输入:s="z*#",k=0

输出:"."

解释:

最终的result是""。由于下标k=0越界,输出为'.'。

提示:

1<=s.length<=105

s只包含小写英文字母和特殊字符'*'、'#'和'%'。

0<=k<=1015

处理s后得到的result的长度不超过1015。

问题分析:

这个问题可以分成以下两步来处理:

  • 当提取出原字符串s中的一个字符后,根据该字符是英文字母,还是*、#、%对result进行相应的处理,并返回处理之后的result,这一功能由process_one_step(c,result)函数来实现,其中c为提取出的字符,result则是之前处理得到的结果。
  • 对原字符串s按顺序依次进行字符解析,将解析出的字符c传入process_one_step(c,result)函数进行处理,如果是首次从s中解析出第一个字符c,则给result传入一个’’空字符,否则将上一次处理之后返回的字符串result作为这一次的参数传入,所有的字符解析完毕,将最后得到的字符串result返回,这一功能由函数process_all(s)实现。

主程序则根据输入的s,调用函数process_all(s)得到最后的结果result,并根据result的值和输入的k值决定输出不同的结果。

程序如下:

#对字符串s解析出字符c,根据c值的不同对传入result字符串进行相应处理,最后返回处理之后的result
def process_one_step(c,result):if c=='*':n = len(result)print(f'因为解析出的字符为*,所以删除最后一个字符{result[-1]},result变成{result[:n-1]}')result=result[:n-1]elif c=='#':print(f'因为解析出的字符为#,所以将{result}复制一份加在后面,result变成{2*result}')result=result*2elif c=='%':print(f'因为解析出的字符为%,所以将result由{result}反转为{result[::-1]}')result=result[::-1]else:print(f'因为解析出的字符为{c},是一个小写英文字母,所以加在{result}后面,result变成{result+c}')result=result+creturn result#对字符串s依次进行解析,调用解析字符处理函数process_one_step(c,result)得到最终的处理结果result并返回
def process_all(s):result=''print("最开始的result为''")for i in s:print(f'从字符串{s}中解析出字符{i}')result=process_one_step(i,result)# print(f'经过处理之后的字符串为{result}')return result#主程序
s=input('pls input s=')
k=int(input('pls input k='))
result=process_all(s)
print('经过处理得到最终的结果:','""' if result=='' else result)
if result=='' or k>len(result)-1:print('最终输出:.')
else:print(f'第{k}个字符为',result[k])

运行实例一

pls input s=ab**

pls input k=0

最开始的result为''

从字符串ab**中解析出字符a

因为解析出的字符为a,是一个小写英文字母,所以加在后面,result变成a

从字符串ab**中解析出字符b

因为解析出的字符为b,是一个小写英文字母,所以加在a后面,result变成ab

从字符串ab**中解析出字符*

因为解析出的字符为*,所以删除最后一个字符b,result变成a

从字符串ab**中解析出字符*

因为解析出的字符为*,所以删除最后一个字符a,result变成

经过处理得到最终的结果: ""

最终输出:.

运行实例二

pls input s=abc*d#a%

pls input k=4

最开始的result为''

从字符串abc*d#a%中解析出字符a

因为解析出的字符为a,是一个小写英文字母,所以加在后面,result变成a

从字符串abc*d#a%中解析出字符b

因为解析出的字符为b,是一个小写英文字母,所以加在a后面,result变成ab

从字符串abc*d#a%中解析出字符c

因为解析出的字符为c,是一个小写英文字母,所以加在ab后面,result变成abc

从字符串abc*d#a%中解析出字符*

因为解析出的字符为*,所以删除最后一个字符c,result变成ab

从字符串abc*d#a%中解析出字符d

因为解析出的字符为d,是一个小写英文字母,所以加在ab后面,result变成abd

从字符串abc*d#a%中解析出字符#

因为解析出的字符为#,所以将abd复制一份加在后面,result变成abdabd

从字符串abc*d#a%中解析出字符a

因为解析出的字符为a,是一个小写英文字母,所以加在abdabd后面,result变成abdabda

从字符串abc*d#a%中解析出字符%

因为解析出的字符为%,所以将result由abdabda反转为adbadba

经过处理得到最终的结果: adbadba

第4个字符为 d

运行实例三

pls input s=ab*#%

pls input k=4

最开始的result为''

从字符串ab*#%中解析出字符a

因为解析出的字符为a,是一个小写英文字母,所以加在后面,result变成a

从字符串ab*#%中解析出字符b

因为解析出的字符为b,是一个小写英文字母,所以加在a后面,result变成ab

从字符串ab*#%中解析出字符*

因为解析出的字符为*,所以删除最后一个字符b,result变成a

从字符串ab*#%中解析出字符#

因为解析出的字符为#,所以将a复制一份加在后面,result变成aa

从字符串ab*#%中解析出字符%

因为解析出的字符为%,所以将result由aa反转为aa

经过处理得到最终的结果: aa

最终输出:.

细心分析,准确提取功能,并实现为相应的函数,是完成这个问题的关键。

http://www.dtcms.com/a/285047.html

相关文章:

  • 魔术公式轮胎simulink模型建立及参数拟合
  • 实现atm提款简易代码
  • ​​孤儿进程:当父进程先离开时会发生什么?
  • LeetCode|Day17|242. 有效的字母异位词|Python刷题笔记
  • 云服务器的数据如何备份和恢复?
  • Leetcode刷题营第二十八题:二叉树的前序遍历
  • CSS关键字:initial、revert、unset傻傻分不清
  • 打造智慧园区新生态
  • Au速成班-乐理知识补充+网页下载音乐
  • 分层图最短路径算法详解
  • 大模型领域主流向量模型相似度算法、架构及指标对比
  • centos 新加磁盘分区动态扩容
  • 服务器数据恢复—raid5磁盘阵列崩溃如何恢复数据?
  • C 语言基础第 08 天:数组与冒泡排序
  • 测试学习之——Pytest Day3
  • Maven详细解
  • Helm-k8s包管理工具(一)核心概念、helm工作目录
  • 搞清MVCC
  • SpringMVC @ResponseBody注解详解
  • Postman接口测试实现UI自动化测试
  • 巧用 Golang 函数特性实现单元测试中的数据库操作 Mock
  • 使用Jmeter进行http接口性能测试
  • 可获得的最大点数
  • https与DNS的运行流程
  • 在ubuntu系统上搭建svn服务器的做法
  • 【分治思想解题框架】【分解、求解、合并】
  • 用图片生成高保真3D模型!Hi3DGen以法线为桥,为高清三维几何生成另辟蹊径
  • 记录timesfm2.0复现及调优
  • CAD model dataset 下载
  • 云徙科技----一面(全栈开发)