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

算法训练第八天

344.反转字符串

思路:

我们用双指针来解,i指向开头,j指向结尾,当i小于j时,每次交换s[i],s[j]即可。

代码:

class Solution(object):def reverseString(self, s):""":type s: List[str]:rtype: None Do not return anything, modify s in-place instead."""i = 0j = len(s)-1while i<j:s[i],s[j] = s[j],s[i]i+=1j-=1return s

541.反转字符串II

思路:

因为python中的字符串是不可变类型,因此我们需要将字符串转为字符数组,然后再进行修改。我们使用双指针和滑动窗口算法,使用i指向滑动窗口的起始位置,j指向滑动窗口的最后一个元素,然后反转。只是最后需要判断结束循环时滑动窗口的状态。

代码:

class Solution(object):def reverse_str(self,s,left,right):i = leftj = rightwhile i<j:s[i],s[j] = s[j],s[i]i+=1j-=1def reverseStr(self, s, k):""":type s: str:type k: int:rtype: str"""i = 0j = 0str = list(s)while j < len(str)-1:while j - i + 1 < 2 * k and j < len(str)-1:j += 1if j==len(str)-1:breakself.reverse_str(str, i, i + k - 1)i = j + 1j += 1if j-i+1<k:self.reverse_str(str,i,j)else:self.reverse_str(str, i, i + k - 1)ans = "".join(str)return ans

54.替换数字

思路:

我们使用的是python,因此必须要开一个辅助数组,那这样就很简单了,我们只需要遍历字符串放入数组,如果是数字,就放入一个number就好了。

代码:

def main(s):str = list(s)new_str = []for i in str:if ord(i)>=ord('0') and ord(i)<=ord('9'):new_str.append('number')else:new_str.append(i)print(''.join(new_str))if __name__=='__main__':s = input()main(s)
http://www.xdnf.cn/news/11957.html

相关文章:

  • 电气架构/域控制器/中央计算平台技术论坛
  • 考研系列—操作系统:冲刺笔记(4-5章)
  • 自动化测试工具playwright中文文档-------18.模拟
  • 宝塔使用docker创建n8n
  • 每日一令:Linux 极简通关指南 - 汇总
  • 树莓派超全系列教程文档--(54)如何使用rsync在计算机之间同步文件夹
  • MCPO:使用MCP工具为Open-WebUI/Ollama助力
  • 渗透测试服务如何全方位评估企业安全状况并揭示潜在缺陷?
  • SpringBoot(七) --- Redis基础
  • 在Windows11上安装 Ubuntu WSL
  • 大语言模型备案与深度合成算法备案的区别与联系
  • Rebel系列数据记录仪:智能车载数据采集专家
  • kafka命令
  • 【unity游戏开发入门到精通——通用篇】AssetBundle(AB包)和AssetBundleBrowser的使用介绍
  • 数据结构期末PTA选择汇总
  • L1-019 谁先倒 (15 分)
  • [安卓/ios辅助工具]给按键精灵脚本做一个日志悬浮窗
  • 制造业数字化转型解决方案及应用
  • rk3588开发板实现磁盘自动挂载vmware共享文件夹设置
  • C学习--内存管理
  • 2. 库的操作
  • 企业如何抵御复杂网络攻击?
  • Delphi用if else实现 select case、switch语句功能,实现case 以字符串为分类条件。
  • Java对象创建过程
  • 操作系统入门:核心概念与设计逻辑
  • 数字孪生在智能制造中的实践:某汽车总装车间的全流程仿真优化
  • https和http有什么区别-http各个版本有什么区别
  • DINO-R1
  • 商务合同范本智能审核系统 AI 大模型处理方案
  • 探索分布式存储与通信:去中心化共享及通訊(DSAC)