【剑指offer】学习计划day3
目录
一. 前言
二.替换空格
a.题目
b.题解分析
c.AC代码
三. 左旋转字符串
a.题目
b.题解分析
c.AC代码
一. 前言
本系列是针对Leetcode中剑指offer学习计划的记录与思路讲解。详情查看以下链接:
剑指offer-学习计划https://leetcode.cn/study-plan/lcof/?progress=x56gvoct
本期是本系列的day3,今天的主题是----》字符串(简单)
题目编号:JZ05,JZ58
二.替换空格
a.题目
b.题解分析
由于针对不同语言,字符串被设计成可变和不可变两种,因此我们需要进行分类讨论
情景1. 字符串不可变
假如我们使用的是C语言,题目传入的是一个字符串常量,是不可变的,即无法直接修改字符串的某一位字符。因此我们需要额外新建一个足够大的字符数组,然后遍历1次原字符串对字符数组进行填充即可。时间复杂度为O(N),空间复杂度也为O(N)。
情景2. 字符串可变
而假如我们使用了C++,题目传入的是一个string类型的变量,是可变的。当然你依旧可以使用一个足够大的辅助空间解决本题。但如果你想把这道题目做到极致,就要充分利用string可变的特性,对字符串进行原地修改。
第一步:显然我们需要扩充字符串到每个空格替换成"%20"之后的大小。
第二步:使用双指针法,一个指针从后往前遍历原字符串,一个指针从后往前填充新字符串。在这个过程中,如果遇到空格,则将其替换为"%20"。过程如下:
额外补充:时间复杂度为O(N),空间复杂度为O(1)。可能有小伙伴会有疑问:为什么要从后往前遍历,从前往后不行吗?答案显然是可以的,但是从前往后遍历替换空格时无可避免的要将后面的所有字符进行向后移动,移动字符需要O(N)的时间,整个过程的时间复杂度就为
,时间开销较大。一般很多数组填充类的问题,都可以先预先给数组扩容带填充后的大小,然后在从后向前进行操作。
c.AC代码
//字符串不可变,采用额外空间
char* replaceSpace(char* s)
{char* cur = s;int spaceNum = 0;//遍历字符串记录有多少空格while (*cur){if (*cur == ' '){spaceNum++;}cur++;}cur = s;//分配合适的空间,这里求原字符串大小不能用sizeof(),s是指针char* ret= (char*)malloc(strlen(s)+1 + spaceNum * 2);int retSize = 0;//遍历字符串对数组进行赋值while (*cur){if (*cur == ' '){//替换空格strcpy(ret + retSize, "%20");retSize += 3;}else{ret[retSize] = *cur;retSize++;}cur++; //指向下一字符}ret[retSize] = '\0'; //不要忘记添加字符串结束标志return ret;
}
//字符串可变,双指针法class Solution {
public:string replaceSpace(string s){int spaceNum = 0; // 统计空格的个数int pOld = s.size() - 1; //原字符串最后一个元素下标for (int i = 0; i < s.size(); i++){if (s[i] == ' '){spaceNum++;}}s.resize(s.size() + spaceNum * 2); //扩容int pNew = s.size() - 1; //新字符串最后一个元素下标//双指针进行赋值,遇到空格进行替换while (pOld > pNew) //当pOld = pNew时说明前面已经没有空格了{if (s[pOld] != ' '){s[pNew] = s[pOld];}else{s[pNew--] = '0';s[pNew--] = '2';s[pNew] = '%';}pNew--;pOld--;}return s;}
};
三. 左旋转字符串
a.题目
b.题解分析
法1. 辅助空间法
第一种方法最简单明了:首先建立一个辅助字符数组,然后遍历字符串,将前n个字符放入数组的后n个位置,剩下的字符放入数组前端即可。时间复杂度为O(N),空间复杂度为O(N)。
法2. 三步翻转法
此方法非常巧妙,思路如下:先翻转前n个字符,再翻转剩下的字符,最后翻转整个字符串。通过这三次翻转,我们便可以完成左旋n个字符的目的。具体过程如下:
但是由于涉及到字符串的修改,因此像C语言这些字符串不可修改的语言还是要建立辅助空间,时间复杂度为O(N),空间复杂度为O(N);而像C++这些语言就没有这种顾虑,直接原地修改即可,时间复杂度为O(N),空间复杂度为O(1)。
c.AC代码
//辅助空间的方式
char* reverseLeftWords(char* s, int n)
{//防止输入的n过大,模上字符串的长度。因为长度为n的字符串左旋n个字符相当于没变n %= strlen(s);int resSize = 0;char* res = (char*)malloc(strlen(s) + 1);//申请辅助空间//后面的字符放到前面for (int i = n; i < strlen(s); i++){res[resSize] = s[i];resSize++;}//前面n个字符放到后面for (int i = 0; i < n; i++){res[resSize] = s[i];resSize++;}res[resSize] = '\0';return res;
}
//逆置的方式//C语言写法
void reverse(char* s, int left, int right)
{assert(s);//逆置字符串while (left < right){char tmp = s[left];s[left] = s[right];s[right] = tmp;left++;right--;}
}
char* reverseLeftWords(char* s, int n)
{//防止输入的n过大,我们模上字符串的长度。因为长度为n的字符串左旋n个字符相当于没变n %= strlen(s);//申请辅助空间char* res = (char*)malloc(strlen(s) + 1);//拷贝到新空间strcpy(res, s);//三步逆置reverse(res, 0, n - 1);reverse(res, n, strlen(s)-1);reverse(res, 0, strlen(s) - 1);return res;
}//C++写法
class Solution {
public:string reverseLeftWords(string s, int n) {//防止输入的n过大,模上字符串的长度。因为长度为n的字符串左旋n个字符相当于没变n %= s.size();//逆置前n个字符,reverse函数在algorithm头文件中reverse(s.begin(), s.begin() + n);//逆置后续字符reverse(s.begin() + n, s.end());//整体逆置reverse(s.begin(), s.end());return s;}
};
以上,就是本期的全部内容啦🌸
制作不易,能否点个赞再走呢🙏
相关文章:

【剑指offer】学习计划day3
目录 一. 前言 二.替换空格 a.题目 b.题解分析 c.AC代码 三. 左旋转字符串 a.题目 b.题解分析 c.AC代码 一. 前言 本系列是针对Leetcode中剑指offer学习计划的记录与思路讲解。详情查看以下链接: 剑指offer-学习计划https://leetcode.cn/stud…...

QT DAY1
做一个窗口界面 #include "mainwindow.h" #include "ui_mainwindow.h"MainWindow::MainWindow(QWidget *parent) :QMainWindow(parent),ui(new Ui::MainWindow) {ui->setupUi(this);//设置窗口标题、图标this->setWindowTitle("Fly_Chat")…...

Mybatis-puls——条件查询的三种格式+条件查询null判定+查询投影
前言 在mybatis_plus的封装中的Wrapper<T>接口参数就是用于封装查询条件 在测试类中启动如上一个简单的查询,然后控制台运行会输出一大堆无关日志,这里先把这些日志关闭 去除无关日志文件 先新建一个XML配置文件 然后变成如下,这里…...

网络安全(黑客)自学
建议一:黑客七个等级 黑客,对很多人来说充满诱惑力。很多人可以发现这门领域如同任何一门领域,越深入越敬畏,知识如海洋,黑客也存在一些等级,参考知道创宇 CEO ic(世界顶级黑客团队 0x557 成员…...
通过一个实际例子说明Django中的数据库操作方法OneToOneField()的用法【数据表“一对一”关系】
当我们在Django中定义一个模型时,可以使用OneToOneField来建立一个一对一的关系。这种关系表示两个模型之间的一种特殊关联,其中一个模型的实例只能与另一个模型的实例关联。 让我们以一个简单的示例来说明OneToOneField的用法。假设我们正在构建一个简…...

HarmonyOS学习路之开发篇—数据管理(对象关系映射数据库)
HarmonyOS对象关系映射(Object Relational Mapping,ORM)数据库是一款基于SQLite的数据库框架,屏蔽了底层SQLite数据库的SQL操作,针对实体和关系提供了增删改查等一系列的面向对象接口。应用开发者不必再去编写复杂的SQ…...

实验:验证TCP套接字传输的数据不存在数据边界
来源:《TCP/IP网络编程》 学习ing 自己动手,把坑踩一遍,也可以学习到很多。 Linux环境下: 客户端: #include <stdio.h> #include <stdlib.h> #include <string.h> #include <unistd.h> #include <…...

【网络】协议的定制与Json序列化和反序列化
文章目录 应用层初识TCP协议通讯流程定制协议再谈协议网络版本计算器Protocal.hppCalServerCalClient Json的安装 应用层 我们程序员写的一个个解决我们实际问题, 满足我们日常需求的网络程序, 都是在应用层 初识TCP协议通讯流程 建立链接和断开链接 基于TCP协议,…...
浙大数据结构第一周最大子列和问题
题目详情: 给定K个整数组成的序列{ N1, N2, ..., NK },“连续子列”被定义为{ Ni, Ni1, ..., Nj },其中 1≤i≤j≤K。“最大子列和”则被定义为所有连续子列元素的和中最大者。例如给定序列{ -2, 11, -4, 13, -5, -2 }ÿ…...

Selenium基础 — Selenium自动化测试框架介绍
1、什么是selenium Selenium是一个用于Web应用程序测试的工具。只要在测试用例中把预期的用户行为与结果都描述出来,我们就得到了一个可以自动化运行的功能测试套件。Selenium测试套件直接运行在浏览器中,就像真正的用户在操作浏览器一样。Selenium也是…...

力扣竞赛勋章 | 排名分数计算脚本
文章目录 力扣竞赛勋章介绍竞赛评分算法脚本(本文的重点内容)运行结果 代码修改自:https://leetcode.cn/circle/discuss/6gnvEj/ 原帖子的代码无法正常运行。 力扣竞赛勋章介绍 https://leetcode.cn/circle/discuss/0fKGDu/ 如果你想知道自…...
win10 远程 ubuntu 18.04 桌面
win10 远程 ubuntu 18.04 桌面 我们要在Windows 10上远程连接到Ubuntu 18.04,您需要按照以下步骤进行设置: 1. 在Ubuntu 18.04上安装并启用远程桌面服务。打开终端,并运行以下命令来安装xrdp: sudo apt update sudo apt instal…...

c++ -- STL
【C/C】STL详解_cstl_沉晓的博客-CSDN博客 Learning Record have done assignment class template An excellent programmer only needs to know how to use containers to improve program encapsulation and reduce coupling, without understanding the underlying pri…...

文字识别(OCR)介绍与开源方案对比
目录 文字识别(OCR)介绍与开源方案对比 一、OCR是什么 二、OCR基本原理说明 三、OCR基本实现流程 四、OCR开源项目调研 1、tesseract 2、PaddleOC 3、EasyOCR 4、chineseocr 5、chineseocr_lite 6、cnocr 7、商业付费OCR 1)腾讯…...

Modbus tcp转ETHERCAT在Modbus软件中的配置方法
Modbus tcp和ETHERCAT是两种不同的协议,这给工业生产带来了很大的麻烦,因为这两种设备之间无法通讯。但是,远创智控YC-ECT-TCP网关的出现,却为这个难题提供了解决方案。 YC-ECT-TCP网关能够连接到Modbus tcp总线和ETHERCAT总线中…...

开源点云数据集整理汇总
目录 一、ModelNet401. 网址2. 模型 二、ShapeNet1. 网址2. 模型 三、S3DIS Dataset1. 网址2. 模型 四、ScanNet1. 网址2. 模型 五、RGB-D Object Dataset1. 网址2. 模型 六、 NYU Depth Dataset V2 (纽约大学深度数据集)1. 网址2. 模型 七、 The Stanfo…...

【全栈开发指南】VUE前端路由设计及配置
我们在使用Vue.js时,创建单页面应用一定会用到路由,Vue Router 是 Vue.js 官方的路由管理器,我们在开发框架中过程中,需要结合Vue Router路由管理器提供的功能,设计和实现系统中菜单的配置。 一、实现原理 一级菜单r…...

C语言程序环境和预处理
本章主要以图片和文字的形式给大家讲解 程序的翻译环境和程序的执行环境 在ANSI C的任何一种实现中,存在两个不同的环境。 第1种是翻译环境,在这个环境中源代码被转换为可执行的机器指令。 第2种是执行环境,它用于实际执行代码 2. 详解编译…...

为摸鱼助力:一份Vue3的生成式ElementPlus表单组件
目录 一、实现背景 二、简介 三、组织架构设计 四、实现方式 五、代码示例 六、示例代码效果预览 七、项目预览地址 & 项目源码地址 目前项目还有诸多待完善的地方,大家有好的想法、建议、意见等欢迎再次评论,或于github提交Issues 一、实现…...
数通工作中常见问题与解决方法
城域网,硬件,交换机开局 1、环路产生,现象,怎么解决 一般是物理拓扑存在环路,导致数据互传,Mac地址漂移,产生环路; Cpu利用率变高,端口流量接近100%,有mac…...
conda相比python好处
Conda 作为 Python 的环境和包管理工具,相比原生 Python 生态(如 pip 虚拟环境)有许多独特优势,尤其在多项目管理、依赖处理和跨平台兼容性等方面表现更优。以下是 Conda 的核心好处: 一、一站式环境管理:…...

MongoDB学习和应用(高效的非关系型数据库)
一丶 MongoDB简介 对于社交类软件的功能,我们需要对它的功能特点进行分析: 数据量会随着用户数增大而增大读多写少价值较低非好友看不到其动态信息地理位置的查询… 针对以上特点进行分析各大存储工具: mysql:关系型数据库&am…...
多场景 OkHttpClient 管理器 - Android 网络通信解决方案
下面是一个完整的 Android 实现,展示如何创建和管理多个 OkHttpClient 实例,分别用于长连接、普通 HTTP 请求和文件下载场景。 <?xml version"1.0" encoding"utf-8"?> <LinearLayout xmlns:android"http://schemas…...

UDP(Echoserver)
网络命令 Ping 命令 检测网络是否连通 使用方法: ping -c 次数 网址ping -c 3 www.baidu.comnetstat 命令 netstat 是一个用来查看网络状态的重要工具. 语法:netstat [选项] 功能:查看网络状态 常用选项: n 拒绝显示别名&#…...

从零开始打造 OpenSTLinux 6.6 Yocto 系统(基于STM32CubeMX)(九)
设备树移植 和uboot设备树修改的内容同步到kernel将设备树stm32mp157d-stm32mp157daa1-mx.dts复制到内核源码目录下 源码修改及编译 修改arch/arm/boot/dts/st/Makefile,新增设备树编译 stm32mp157f-ev1-m4-examples.dtb \stm32mp157d-stm32mp157daa1-mx.dtb修改…...
#Uniapp篇:chrome调试unapp适配
chrome调试设备----使用Android模拟机开发调试移动端页面 Chrome://inspect/#devices MuMu模拟器Edge浏览器:Android原生APP嵌入的H5页面元素定位 chrome://inspect/#devices uniapp单位适配 根路径下 postcss.config.js 需要装这些插件 “postcss”: “^8.5.…...
【Kafka】Kafka从入门到实战:构建高吞吐量分布式消息系统
Kafka从入门到实战:构建高吞吐量分布式消息系统 一、Kafka概述 Apache Kafka是一个分布式流处理平台,最初由LinkedIn开发,后成为Apache顶级项目。它被设计用于高吞吐量、低延迟的消息处理,能够处理来自多个生产者的海量数据,并将这些数据实时传递给消费者。 Kafka核心特…...
LangChain 中的文档加载器(Loader)与文本切分器(Splitter)详解《二》
🧠 LangChain 中 TextSplitter 的使用详解:从基础到进阶(附代码) 一、前言 在处理大规模文本数据时,特别是在构建知识库或进行大模型训练与推理时,文本切分(Text Splitting) 是一个…...

MySQL体系架构解析(三):MySQL目录与启动配置全解析
MySQL中的目录和文件 bin目录 在 MySQL 的安装目录下有一个特别重要的 bin 目录,这个目录下存放着许多可执行文件。与其他系统的可执行文件类似,这些可执行文件都是与服务器和客户端程序相关的。 启动MySQL服务器程序 在 UNIX 系统中,用…...

HTTPS证书一年多少钱?
HTTPS证书作为保障网站数据传输安全的重要工具,成为众多网站运营者的必备选择。然而,面对市场上种类繁多的HTTPS证书,其一年费用究竟是多少,又受哪些因素影响呢? 首先,HTTPS证书通常在PinTrust这样的专业平…...