代码随想录算法训练营第八天 | 字符串:344反转字符串、541反转字符串2、替换数字、翻转字符串内单词、55右旋转字符串
反转字符串
https://leetcode.cn/problems/reverse-string/
反转字符串代码随想录
https://programmercarl.com/0344.反转字符串.html#算法公开课
替换数字
https://kamacoder.com/problempage.php?pid=1064
替换数字代码随想录
https://programmercarl.com/kama54.替换数字.html#其他语言版本
翻转单词
https://leetcode.cn/problems/reverse-words-in-a-string/description/
右旋字符串
https://kamacoder.com/problempage.php?pid=1065
反转字符串
题目
编写一个函数,其作用是将输入的字符串反转过来。输入字符串以字符数组 s 的形式给出。
不要给另外的数组分配额外的空间,你必须原地修改输入数组、使用 O(1) 的额外空间解决这一问题。
题解
- 要求交换 所以一定需要两两交换
- 从前到中间对称交换即可
题解代码
class Solution:
def reverseString(self, s: List[str]) -> None:
"""
Do not return anything, modify s in-place instead.
"""
n = len(s)
for i in range(len(s)//2):
l = i
r = n-i-1
tmp = s[l]
s[l] = s[r]
s[r] = tmp
return s
替换数字
题目
给定一个字符串 s,它包含小写字母和数字字符,请编写一个函数,将字符串中的字母字符保持不变,而将每个数字字符替换为number。 例如,对于输入字符串 "a1b2c3",函数应该将其转换为 "anumberbnumbercnumber"。
题解
- 字符串不能直接在原位修改
- 但可以考虑转为list 再转回字符串
- 字符串可以比大小
题解代码
input_str = input()
str_ = list(input_str)
for i in range(len(str_)):
if "1"<=str_[i]<="9":
str_[i]="number"
output = "".join(str_)
print(output)
55.右旋转字符串
题目
字符串的右旋转操作是把字符串尾部的若干个字符转移到字符串的前面。给定一个字符串 s 和一个正整数 k,请编写一个函数,将字符串中的后面 k 个字符移到字符串的前面,实现字符串的右旋转操作。
例如,对于输入字符串 "abcdefg" 和整数 2,函数应该将其转换为 "fgabcde"。
题解
- 两次反转等于位置不变
- 向右旋转 = 整体反向+前后分别反向
题解代码
num = input()
str_ = input()
num = int(num)
def righerreverse(num,str_):
str_ = str_[::-1]
res_str = str_[0:num][::-1]+str_[num:][::-1]
return res_str
res_str = righerreverse(num,str_)
print(res_str)
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 三行代码完成国际化适配,妙~啊~
· .NET Core 中如何实现缓存的预热?