【C++初阶】string类常见题目详解(一)—— 仅仅反转字母、字符串中的第一个唯一字母、字符串最后一个单词的长度、验证回文串、字符串相加

news2024/9/23 15:21:38

在这里插入图片描述

​📝个人主页:@Sherry的成长之路
🏠学习社区:Sherry的成长之路(个人社区)
📖专栏链接:C++初阶
🎯长路漫漫浩浩,万事皆有期待

上一篇博客:【C++初阶】C++STL详解(二)—— string类的模拟实现

文章目录

  • 题目一:仅仅反转字母
  • 题目二:字符串中的第一个唯一字母
  • 题目三:最后一个单词的长度
  • 题目四:验证回文串
  • 题目五:字符串相加
  • 总结:

题目一:仅仅反转字母

链接:917. 仅仅反转字母
题目描述:
 给定一个字符串,返回“反转后的”字符串,其中不是字母的字符都保留在原地,而所有字母的位置发生反转。

示例:
 输入:s = “Test1ng-Leet=code-Q!”
 输出:“Qedo1ct-eeLg=ntse-T!”

思路:
 使用两个指针,开始时头指针指向字符串开头,尾指针指向字符串末尾(’\0’的前一个字符)。头指针先向后寻找待反转字母,尾指针再向前寻找待反转字母,然后反转这两个待反转字母即可。重复该步骤,直到头指针和尾指针发生错位为止。

代码:

class Solution {
public:
	//判断字符ch是否是字母
	bool IsLetter(char ch)
	{
		if ((ch >= 'a'&&ch <= 'z') 
		 || (ch >= 'A'&&ch <= 'Z'))
			return true;
		else
			return false;
	}
	//仅仅反转字母
	string reverseOnlyLetters(string s) {
		if (s.empty()) //若s为空字符串,则返回其本身
			return s;

		size_t begin = 0, end = s.size() - 1; //定义头指针和尾指针,用于反转字母
		while (begin < end) //当还有字母可反转时,循环继续
		{
			while (begin < end && !IsLetter(s[begin])) //头指针寻找待反转字母
				begin++;

			while (begin < end && !IsLetter(s[end])) //尾指针寻找待反转字母
				end--;

			swap(s[begin], s[end]); //交换这两个待反转字母
			begin++;
			end--;
		}
		return s; //返回反转后的字符串
	}
};

在这里插入图片描述

注意:若传入的字符串尾空字符串,则直接返回即可。

题目二:字符串中的第一个唯一字母

链接:387. 字符串中的第一个唯一字符
题目描述:
 给定一个字符串,找到它的第一个不重复的字母,并返回它的索引。如果不存在,则返回-1。

示例:
 输入: s = “loveleetcode”
 输出: 2

思路:
 用一个含义26个元素的数组统计26个字母在字符串中出现的次数,然后再遍历一次字符串,寻找字符串中第一个只出现一次的字母,并返回它的索引,若不存在,则返回-1。

代码:

class Solution {
public:
	int firstUniqChar(string s) {
		size_t table[26] = { 0 };
		//统计26个字母在字符串中出现的次数
		for (size_t i = 0; i < s.size(); i++)
		{
			table[s[i] - 'a']++;
		}
		//寻找字符串中的第一个只出现一次字母
		for (size_t i = 0; i < s.size(); i++)
		{
			if (table[s[i] - 'a'] == 1)
				return i; //返回下标索引
		}
		return -1; //不存在,返回-1
	}
};

在这里插入图片描述

题目三:最后一个单词的长度

链接:HJ1 字符串最后一个单词的长度
题目描述:
 计算字符串最后一个单词的长度,单词以空格隔开,字符串长度小于5000。

示例:
 输入:s = “Hello World”
 输出:5
 解释:最后一个单词是“World”,长度为5。

思路:
 先找到字符串中最后一个空格的位置,空格之后的字符个数就是最后一个单词的长度。若字符串中不存在空格,则字符串的长度就是最后一个单词的长度。

重点:
 该题的思路容易想到,但该题真正的难点不是如何求得字符串中最后一个单词的长度,而是如何读取一个含有空格的字符串。因为操作符>>读取到空格便会停止,所以不能使用>>读取目标字符串,这时我们就需要用到getline函数了,该函数便可以读取含有空格的内容。

代码:

#include <iostream>
#include <string>
using namespace std;
int main()
{
	string s;
	getline(cin, s); //从cin读取一行含有空格的字符串
	size_t pos = s.rfind(' '); //获取字符串中最后一个空格的位置
	if (pos == string::npos) //字符串中不含空格
	{
		//输出字符串的长度
		cout << s.size() << endl;
	}
	else //字符串中含有空格
	{
		//输出字符串的长度 - 最后一次出现空格的位置 - 1
		cout << s.size() - pos - 1 << endl;
	}
	return 0;
}

在这里插入图片描述

题目四:验证回文串

链接:验证回文串
题目描述:
 给定一个字符串,验证它是否是回文串,只考虑字母和数字字符,可以忽略字母的大小写。

示例:
 输入: s = “A man, a plan, a canal: Panama”
 输出:true
 解释:“amanaplanacanalpanama” 是回文串。

思路:
 题目中说到可以忽略字母大小写,即’a’可与’a’匹配,‘a’还可与’A’匹配,所以我们可以先将字符串中所有的大写字母转换为小写字母,然后再进行进一步判断。
 判断时使用两个指针,开始时头指针指向字符串开头,尾指针指向字符串末尾(’\0’的前一个字符)。头指针先向后寻找待判断的字母或数字字符,尾指针再向前寻找待判断的字母或数字字符,然后判断这两个字符是否相等,若相等,则继续下一次判断;若不相等,则该字符串不是回文串。重复该步骤,直到头指针和尾指针发生错位为止,此时便可确定该字符串是回文串。

代码:

class Solution {
public:
	//判断ch是否是小写字母或数字字符
	bool isLetterOrNumber(char ch)
	{
		if ((ch >= 'a' && ch <= 'z')
			|| (ch >= '0' && ch <= '9'))
			return true;
		else
			return false;
	}
	//验证回文串
	bool isPalindrome(string s) {
		//将字符串中所有大写字母转为小写字母
		for (auto& ch : s)
		{
			if (ch >= 'A' && ch <= 'Z')
				ch += 32;
		}
		int begin = 0, end = s.size() - 1; //定义头指针和尾指针,用于验证回文串
		while (begin < end) //当还有字母未判断时,循环继续
		{
			while (begin < end && !isLetterOrNumber(s[begin])) //头指针寻找待判断的字母或数字字符
				begin++;

			while (begin < end && !isLetterOrNumber(s[end])) //尾指针寻找待判断的字母或数字字符
				end--;

			if (s[begin] == s[end]) //待判断字符相等,继续下一次判断
			{
				begin++;
				end--;
			}
			else
			{
				return false; //待判断字符不相等,该字符串不是回文串
			}
		}
		return true; //字符串中所有字符判断完毕,该字符串是回文串
	}
};

在这里插入图片描述

题目五:字符串相加

链接:415. 字符串相加
题目描述:
 给定两个字符串形式的非负整数num1和num2,计算它们的和。

示例:
 输入:“999”, “1”
 输出:“1000”

思路:
 和我们平时计算两个数的和一样,我们从两个字符串的最后一个数字开始进行相加,并设置一个变量记录是否需要进位,这样一来,两个字符串相加的时候,每一位置的数字 = 字符串1对应位置的数字 + 字符串2对应位置的数字 + 进位变量,若相加后该位置的数字大于9,则说明需要进位,这时我们设置进位变量为1(两个数字相加,最多只能进位1),并将该位置的数字减去10后的结果作为相加后该位置的数字即可,如此进行下去,直到两个字符串都遍历完毕即可。
注意:两个字符串相加结束后还需要判断进位变量是否为1,若为1,则需要头插一个字符1到最终的字符串中。

代码:

class Solution {
public:
	string addStrings(string num1, string num2) {
		int end1 = num1.size() - 1, end2 = num2.size() - 1; //定义两个字符串的尾指针
		string RetStr; //存储两个字符串相加后的结果
		int next = 0; //标识进位
		while (end1 >= 0 || end2 >= 0) //两个字符串中有一个未遍历完,则继续循环
		{
			int val1 = 0; //第一个字符串等待相加的数字
			if (end1 >= 0)
			{
				val1 = num1[end1] - '0';//存的是ASCALL码值,需要-'0'=48
				end1--;
			}
			int val2 = 0; //第二个字符串等待相加的数字
			if (end2 >= 0)
			{
				val2 = num2[end2] - '0';
				end2--;
			}
			int RetVal = val1 + val2 + next; //两个数字相加后的结果,注意需要加上进位
			if (RetVal > 9) //判断是否需要进位
			{
				RetVal -= 10;
				next = 1; //需要进位,设置next为1
			}
			else
			{
				next = 0; //不需进位,设置next为0
			}
			RetStr.insert(0, 1, RetVal + '0'); //将RetVal头插到RetStr
		}
		if (next == 1) //判断是否还需进位
			RetStr.insert(0, 1, '1'); //将'1'头插到RetStr
		return RetStr; //返回这两个字符串相加后的结果
	}
};

在这里插入图片描述

优化:
 代码中,我们每得到一个位置(个位、十位、百位…)的结果就需要头插一个数字到最终的字符串中。而我们知道,头插的代价是比较大的,因为我们每次进行头插就需要将所有的数据都向后挪动一位,留出最前面的位置以供插入,这种算法的时间复杂度达到O(N)。
 因此,我们可以将得到的每一位数字都尾插到字符串后面,只需最后进行一次字符串反转即可。

优化后的代码:

class Solution {
public:
	string addStrings(string num1, string num2) {
		int end1 = num1.size() - 1, end2 = num2.size() - 1; //定义两个字符串的尾指针
		string RetStr; //存储两个字符串相加后的结果
		int next = 0; //标识进位
		while (end1 >= 0 || end2 >= 0) //两个字符串中有一个未遍历完,则继续循环
		{
			int val1 = 0; //第一个字符串等待相加的数字
			if (end1 >= 0)
			{
				val1 = num1[end1] - '0';
				end1--;
			}
			int val2 = 0; //第二个字符串等待相加的数字
			if (end2 >= 0)
			{
				val2 = num2[end2] - '0';
				end2--;
			}
			int RetVal = val1 + val2 + next; //两个数字相加后的结果,注意需要加上进位
			if (RetVal > 9) //判断是否需要进位
			{
				RetVal -= 10;
				next = 1; //需要进位,设置next为1
			}
			else
			{
				next = 0; //不需进位,设置next为0
			}
			RetStr += (RetVal + '0'); //将RetVal尾插到RetStr
		}
		if (next == 1) //判断是否还需进位
			RetStr += '1'; //将'1'尾插插到RetStr
		reverse(RetStr.begin(), RetStr.end()); //将字符串RetStr进行反转
		return RetStr; //返回这两个字符串相加后的结果
	}
};

总结:

今天我们比较详细地完成了string类的部分常见题目。接下来,我们将继续进行string类的其他常见题目的练习。希望我的文章和讲解能对大家的学习提供一些帮助。

当然,本文仍有许多不足之处,欢迎各位小伙伴们随时私信交流、批评指正!我们下期见~

在这里插入图片描述

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

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

相关文章

【Python 基础篇】Python 集合及集合常用函数

文章目录 导言一、集合的创建和访问二、集合的常用函数len()add()remove()union()intersection()difference()issubset()issuperset()clear() 总结 导言 在Python中&#xff0c;集合&#xff08;Set&#xff09;是一种无序、不重复的数据类型&#xff0c;用于存储多个唯一的元…

HCIP网络笔记分享——广域网协议及BGP协议

第二部分 HCIA回顾一、广域网技术1、HDLC2、PPP3、PAP4、CHAP5、GRE6、运行路由协议 二、动态路由协议1、OSPF2、重发布3、路由策略3.1 抓流量3.2 具体过程 4、BGP 三、BGP边界网关协议1、BGP的数据包2、BGP的状态机3、BGP的工作过程4、BGP的路由黑洞问题5、BGP的防环问题6、BG…

Studio One6.1.1免费中文版电子音乐、摇滚乐制作软件

Studio One6是一款专业的音乐制作软件&#xff0c;该软件提供了全面的音频编辑和混音功能&#xff0c;包括录制、编曲、合成、采样等多种工具&#xff0c;可用于制作各种类型的音乐&#xff0c;如流行音乐、电子音乐、摇滚乐等。 Studio One6.1的主要特点包括&#xff1a; 1. …

深入理解什么是端口(port)

每当看到有人的简历上写着熟悉 tcp/ip, http 等协议时, 我就忍不住问问他们: 你给我说说, 端口是啥吧! 可惜, 很少有人能说得让人满意... 所以这次就来谈谈端口(port), 这个熟悉的陌生人. 在此过程中, 还会谈谈间接层, naming service 等概念, IoC, 依赖倒置等原则以及 TCP 协议…

JavaEE的学习(Spring +Spring MVC + MyBatis)

一、Spring入门 Spring是一个轻量级的控制反转 (IoC-Inversion of Control)和面向切面 (AOP-Aspect Oriented Programming)的容器&#xff08;框架&#xff09;。它采用分层架构&#xff0c;由大约20个模块组成&#xff0c;这些模块分为Core Container、Data Access/Integrati…

什么是计算机蠕虫?

计算机蠕虫诞生的背景 计算机蠕虫的诞生与计算机网络的发展密切相关。20世纪60年代末和70年代初&#xff0c;互联网还处于早期阶段&#xff0c;存在着相对较少的计算机和网络连接。然而&#xff0c;随着计算机技术的进步和互联网的普及&#xff0c;计算机网络得以迅速扩张&…

TC8:SOMEIPSRV_FORMAT_09-10

SOMEIPSRV_FORMAT_09: Undefined bits in the Flag field 目的 Flag字段中的未定义位应静态设置为0 测试步骤 DUT CONFIGURE:启动具有下列信息的服务Service ID:SERVICE-ID-1Instance数量:1Tester:客户端-1监听在网卡上DUT:发送SOME/IP Notification消息Tester:验证接收…

Flutter应用开发,系统样式改不了?SystemChrome 状态栏、导航栏、屏幕方向……想改就改

文章目录 开发场景SystemChrome 介绍SystemChrome的使用导入 SystemChrome 包隐藏状态栏说明 改变状态栏的样式注意事项其他样式说明 锁定屏幕方向锁定屏幕方向实例注意事项 开发场景 开发APP时&#xff0c;我们经常要客制化状态栏、导航栏栏等的样式和风格&#xff0c;Flutte…

网络之网络基础入门

文章目录 前言一、局域网和广域网1.局域网LAN2.广域网WAN3.城域网和校园网4.如何区分广域网和局域网 二、协议1.概念2.理解3.协议分层4.数据传输的条件 三、OSI七层模型&#xff08;了解即可&#xff09;1.概念2.OSI七层模型 四、TCP/IP五层&#xff08;四层&#xff09;模型1.…

TC8:TCP_BASICS_11-17

TCP_BASICS_11: [finwait-2 -> time_wait] delay(2*MSL) -> [closed] 目的 TCP从FINWAIT-2状态到TIME-WAIT状态后,等待2MSL时间后,移动到CLOSED状态 关于为什么要等待2MSL时间,我的文章中讲过太多次了,这里就不提了 测试步骤 Tester:让DUT移动到FINWAIT-2状态Test…

使用Python批量进行数据分析

案例01 批量升序排序一个工作簿中的所有工作表——产品销售统计表.xlsx import xlwings as xw import pandas as pd app xw.App(visible False, add_book False) workbook app.books.open(产品销售统计表.xlsx) worksheet workbook.sheets # 列出工作簿中的所有工作表 fo…

SpringBoot 如何使用 ApplicationEventPublisher 发布事件

SpringBoot 如何使用 ApplicationEventPublisher 发布事件 在 SpringBoot 应用程序中&#xff0c;我们可以使用 ApplicationEventPublisher 接口来发布事件。事件可以是任何对象&#xff0c;当该对象被发布时&#xff0c;所有监听该事件的监听器都会收到通知。 下面是一个简单…

[Leetcode] 0733. 图像渲染

733. 图像渲染 点击上方&#xff0c;跳转至leetcode 题目描述 有一幅以 m x n 的二维整数数组表示的图画 image &#xff0c;其中 image[i][j] 表示该图画的像素值大小。 你也被给予三个整数 sr , sc 和 newColor 。你应该从像素 image[sr][sc] 开始对图像进行 上色填充 。 为…

第八章 MobileNetv3网络详解

系列文章目录 第一章 AlexNet网络详解 第二章 VGG网络详解 第三章 GoogLeNet网络详解 第四章 ResNet网络详解 第五章 ResNeXt网络详解 第六章 MobileNetv1网络详解 第七章 MobileNetv2网络详解 第八章 MobileNetv3网络详解 第九章 ShuffleNetv1网络详解 第十章…

1.RocketMQ的安装与集群架构

RocketMQ快速入门 RocketMQ是阿里巴巴2016年MQ中间件&#xff0c;使用Java语言开发&#xff0c;在阿里内部&#xff0c;RocketMQ承接了例如“双11”等高并发场景的消息流转&#xff0c;能够处理万亿级别的消息。 2.1 准备工作 2.1.1 下载RocketMQ RocketMQ最新版本&#xff1a;…

Redis缓存与数据库如何保证一致性?同步删除+延时双删+异步监听+多重保障方案

导航&#xff1a; 【Java笔记踩坑汇总】Java基础进阶JavaWebSSMSpringBoot瑞吉外卖SpringCloud黑马旅游谷粒商城学成在线MySQL高级篇设计模式常见面试题源码 目录 一、四种基础同步策略 1.1 同步策略 1.2 更新缓存还是删除缓存&#xff1f; 1.2.1 更新缓存的优缺点 1.2.2 …

【PCB专题】Allegro输出光绘文件的基本参数设置和光绘层建立

什么是Gerber PCB设计是一套流程体系,而PCB制造又是另一套流程体系。 PCB设计数据并不等同于PCB制造数据,也就是说PCB制造并不会直接使用我们的PCB设计数据。设计数据需要经过CAM(Computer-Aided Manufacturing 计算机辅助制造)转换成给机器使用的生产数据。 Gerber就是板厂…

【强化学习】动手学强化学习:多臂老虎机问题

动手学强化学习&#xff1a;多臂老虎机问题 强化学习思维导图简介问题介绍问题定义形式化描述累积懊悔估计期望奖励 贪心策略与 ϵ \epsilon ϵ-greedy策略上置信界算法汤普森采样算法参考资料 强化学习思维导图 简介 强化学习关注智能体和环境交互过程中的学习&#xff0c;这…

chatgpt赋能python:Python中的查找方法

Python中的查找方法 Python是一种常用的编程语言&#xff0c;它有很多强大的查找方法。这些方法可以让开发人员轻松地搜索数据、列表和文本。 以下是Python中最常用的查找方法&#xff1a; 列表查找方法 在Python中&#xff0c;可以使用多种方法来查找列表中的元素。以下是…

Python零基础入门(四)——变量,数据类型与运算符

系列文章目录 个人简介&#xff1a;机电专业在读研究生&#xff0c;CSDN内容合伙人&#xff0c;博主个人首页 Python入门专栏&#xff1a;《Python入门》欢迎阅读&#xff0c;一起进步&#xff01;&#x1f31f;&#x1f31f;&#x1f31f; 码字不易&#xff0c;如果觉得文章不…