代码随想录算法训练营day6(字符串)

华子目录

  • 反转字符串
    • 思路
  • 反转字符串II
    • 思路
  • 替换数字
    • 思路

反转字符串

  • https://leetcode.cn/problems/reverse-string/

在这里插入图片描述

思路

  • 使用双指针,初始化时,left指向下标0的位置right指向最后一个元素的下标
  • while left<right时,交换nums[left]nums[right],直到结束整个循环
class Solution:def reverseString(self, s: List[str]) -> None:"""Do not return anything, modify s in-place instead."""left, right = 0, len(s)-1while left<right:s[left],s[right] = s[right], s[left]left+=1right-=1

反转字符串II

  • https://leetcode.cn/problems/reverse-string-ii/description/

在这里插入图片描述

思路

  • 先定义一个反转字符串函数reverse,并传入一个参数返回一个已经反转了的字符串
  • 再以2k步长遍历整个字符串每遍历一次前k个字符串nums[cur:cur+k]传递给上面的函数,接受返回的字符串res=reverse(text),并修改原来的nums[cur:cur+k]=res
#写法1
class Solution:def reverseStr(self, s: str, k: int) -> str:def reverse(text):left, right = 0, len(text)-1while left<right:text[left],text[right] = text[right],text[left]left+=1right-=1return textarr = list(s)for cur in range(0,len(s),2*k):res = reverse(arr[cur:cur+k])arr[cur:cur+k] = resreturn "".join(arr)
#写法2
class Solution:def reverse(self,text):left, right = 0, len(text)-1while left<right:text[left],text[right]=text[right],text[left]left+=1right-=1return textdef reverseStr(self, s: str, k: int) -> str:arr = list(s)for cur in range(0,len(s),2*k):res = self.reverse(arr[cur:cur+k])arr[cur:cur+k]=resreturn "".join(arr)

替换数字

  • https://kamacoder.com/problempage.php?pid=1064

在这里插入图片描述

思路

  • s转化为列表lst,遍历列表lst,如果lst[i]整数,则lst[i] = 'number',否则i++
  • 遍历完之后,将列表lst转化为字符串(使用''.join(lst)
class Solution:def __init__(self):self.t = 'number'self.tmp = ['1', '2', '3', '4', '5', '6', '7', '8', '9', '0']def replace(self):s = input()lst = list(s)for i in range(len(s)):if lst[i] in self.tmp:lst[i] = self.tprint(''.join(lst))obj = Solution()
obj.replace()

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/77425.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Oracle 19c新特性:OCP认证考试与职业跃迁的关键?

在数字化转型的浪潮中&#xff0c;Oracle 19c作为数据库领域的旗舰版本&#xff0c;不仅承载着技术革新的使命&#xff0c;更成为IT从业者职业进阶的“黄金跳板”。无论是企业级应用的高可用性需求&#xff0c;还是云原生架构的快速迭代&#xff0c;Oracle 19c的智能化与多模型…

【MySQL数据库入门到精通】

文章目录 一、SQL分类二、DDL-数据库操作1.查询2.创建数据库3.删除数据库4.使用数据库 三、DDL-表操作1.查询 一、SQL分类 根据功能主要分为DDL DML DQL DCL DDL:Date Definition Language数据定义语言&#xff1a;定义数据库&#xff0c;表和字段 DML:Date Manipulatin Lan…

MCP服务端开发

MCP(Memory, Context, Planning)是一种增强AI系统认知能力的框架,通过整合记忆管理、上下文理解和规划能力,可以显著提升AI系统的表现。下面我将为您开发一个完整的MCP服务端。 概述 我们将使用Python开发一个基于FastAPI的MCP服务端,包含以下核心组件: Memory Manager…

前端:uniapp中uni.pageScrollTo方法与元素的overflow-y:auto之间的关联

在uniapp中&#xff0c;uni.pageScrollTo方法与元素的overflow-y:auto属性之间存在以下关联和差异&#xff1a; 一、功能定位差异 ‌uni.pageScrollTo‌ 属于‌页面级滚动控制‌&#xff0c;作用于整个页面容器‌34。要求页面内容高度必须超过屏幕高度&#xff0c;且由根元素下…

基础知识-指针

1、指针的基本概念 1.1 什么是指针 1.1.1 指针的定义 指针是一种特殊的变量&#xff0c;与普通变量存储具体数据不同&#xff0c;它存储的是内存地址。在计算机程序运行时&#xff0c;数据都被存放在内存中&#xff0c;而指针就像是指向这些数据存放位置的 “路标”。通过指针…

VS远程Linux_CMake项目搭建

VS远程Linux CMake项目搭建 准备工作 远程计算机上安装 gcc: 一个开源的编译器集合, GCC支持多种编程语言的编译&#xff0c;包括C、C、Objective-C、Fortran、Ada、Go、D和Javagdb: GDB&#xff08;GNU Debugger&#xff09;是一个功能强大的调试工具&#xff0c;主要用于调…

替代升级VMware | 云轴科技ZStack构建山西证券一云多芯云平台

通过云轴科技ZStack Cloud云平台&#xff0c;山西证券打造了敏捷部署、简单运维的云平台&#xff0c;不仅兼容x86、海光、鲲鹏三种异构服务器实现一云多芯&#xff0c;还通过云平台虚拟化纳管模块纳管原有VMware虚拟化资源&#xff0c;并对接第三方集中式存储&#xff0c;在保护…

MATLAB - 模型预测控制器(MPC)的稳定性和鲁棒性问题

系列文章目录 目录 系列文章目录 前言 一、被控对象模型 二、初始控制器设计 三、改进初始设计 五、查看软约束 七、参考 前言 您可以检查模型预测控制器设计是否存在潜在的稳定性和鲁棒性问题。具体操作如下 在命令行中&#xff0c;使用审查功能。在 MPC Designer 中&a…

《GPT-4.1深度解析:AI进化新标杆,如何重塑行业未来?》

一、GPT-4.1:AI 领域的 “全能战士” 降临 1.1 发布背景与战略意义 在 OpenAI 的技术迭代版图中,GPT-4.1 被赋予了 “承前启后” 的关键角色。它不仅是 GPT-4o 的全面升级版,更被视为向 GPT-5 过渡的重要桥梁。2025 年 4 月 15 日的发布会上,OpenAI 宣布 GPT-4.1 系列模型…

MySQL+Redis实战教程:从Docker安装部署到自动化备份与数据恢复20250418

MySQLRedis实战教程&#xff1a;从Docker安装部署到自动化备份与数据恢复 一、前言 在企业应用中&#xff0c;对MySQL和Redis运维的要求越来越高&#xff1a; 不能仅是启动就算部署运行稳定、隔离、访问控制、备份恢复、安全可靠&#xff0c;才是 企业级的基本功能 本文将手…

Linux系统编程之守护进程与调试技术

在Linux系统编程中&#xff0c;守护进程&#xff08;Daemon&#xff09;是非常重要的一种概念。它允许程序在后台运行&#xff0c;不受用户交互的影响&#xff0c;并且可以持续长时间地运行。通过了解如何创建和管理守护进程&#xff0c;我们能够开发出更加稳定、高效的系统应用…

Linux中的管道

管道的概念 管道是一种进程间通信的方式。 管道是一种半双工通信机制&#xff0c;数据只能读或写&#xff0c;如果要读写同时进行就要创建两个管道 管道的类型 1、匿名管道PIPE&#xff1a;通常在亲缘进程中使用&#xff08;兄弟、父子&#xff09; 函数参考&#xff1a;匿名管…

深度学习2.4 微积分

2.4.1 导数和微分 2.4.2 偏导数 ![在这里插入图片描述](https://i-blog.csdnimg.cn/direct/17227e00adb14472902baba4da675aed.png 2.4.3 梯度 具体证明&#xff0c;矩阵-向量积

《软件设计师》复习笔记(11.3)——需求获取、分析、定义、验证、管理

目录 一、软件需求概述 真题示例&#xff1a; 二、质量功能部署&#xff08;QFD&#xff09; 三、需求开发流程 需求获取 需求分析 需求定义&#xff08;SRS&#xff09; 需求验证 真题示例&#xff1a; 四、需求管理 真题示例&#xff1a; 一、软件需求概述 软件…

Spring Boot 依赖注入与Bean管理:JavaConfig如何取代XML?

大家好呀&#xff01;今天我们来聊一个超级实用的技术话题 —— Spring Boot 中的依赖注入和Bean管理&#xff0c;特别是JavaConfig是如何一步步取代XML配置的。我知道很多小伙伴一听到"依赖注入"、"Bean管理"这些词就头大&#xff0c;别担心&#xff01;我…

全志H5,NanopiKP1lus移植QT5.12记录

移植步骤 机器环境下载QT5.12.0源码安装交叉编译器修改qmake.conf文件配置编译选项qt5的configure选项说明基本配置选项编译器和链接器选项功能模块配置第三方库集成注意事项 配置过程报错解决配置完成编译过程报错解决编译完成将arm-qt文件夹传送到开发板配置板子环境变量运行…

STM32单片机C语言

1、stdint.h简介 stdint.h 是从 C99 中引进的一个标准 C 库的文件 路径&#xff1a;D:\MDK5.34\ARM\ARMCC\include 大家都统一使用一样的标准&#xff0c;这样方便移植 配置MDK支持C99 位操作 如何给寄存器某个值赋值 举个例子&#xff1a;uint32_t temp 0; 宏定义 带参…

【专题刷题】双指针(四):最接近的三数之和,接雨水

&#x1f4dd;前言说明&#xff1a; 本专栏主要记录本人的基础算法学习以及LeetCode刷题记录&#xff0c;按专题划分每题主要记录&#xff1a;&#xff08;1&#xff09;本人解法 本人屎山代码&#xff1b;&#xff08;2&#xff09;优质解法 优质代码&#xff1b;&#xff…

chili3d调试笔记3 加入c++ 大模型对话方法 cmakelists精读

加入 #include <emscripten/bind.h> #include <emscripten/val.h> #include <nlohmann/json.hpp> 怎么加包 函数直接用emscripten::function&#xff0c;如&#xff1a; emscripten::function("send_to_llm", &send_to_llm); set (CMAKE_C…

[Redis]1-高效的数据结构P2-Set

按照惯例&#xff0c;先丢一个官网文档链接。 上篇我们已经了解了高效的数据结构P1-String与Hash。 这篇&#xff0c;我们继续来了解Redis的 Set 与 Sorted set。 目录 有序集合 Sorted set底层实现 集合 Set总结资料引用 有序集合 Sorted set Redis 有序集合是一组唯一的字符…