从C语言到C++_12(string相关OJ题)(leetcode力扣)

news2025/1/9 19:20:46

 上一篇已经讲了string类的接口函数,然后根据查文档刷了牛客和力扣58最后一个单词的长度,

还有力扣415字符串相加,这篇继续跟着查文档来刷力扣题,体会C++刷题的方便。

目录

917. 仅仅反转字母 - 力扣(LeetCode)

代码解析:

387. 字符串中的第一个唯一字符 - 力扣(LeetCode)

解析代码:

125. 验证回文串 - 力扣(LeetCode)

代码解析:

344. 反转字符串 - 力扣(LeetCode)

解析代码:

541. 反转字符串 II - 力扣(LeetCode)

解析代码:

557. 反转字符串中的单词 III - 力扣(LeetCode)

解析代码:

43. 字符串相乘 - 力扣(LeetCode)

解析代码:

本章完。


917. 仅仅反转字母 - 力扣(LeetCode)

难度简单

给你一个字符串 s ,根据下述规则反转字符串:

  • 所有非英文字母保留在原有位置。

  • 所有英文字母(小写或大写)位置反转。

返回反转后的 s 。

示例 1:

输入:s = "ab-cd"
输出:"dc-ba"

示例 2:

输入:s = "a-bC-dEf-ghIj"
输出:"j-Ih-gfE-dCba"

示例 3:

输入:s = "Test1ng-Leet=code-Q!"
输出:"Qedo1ct-eeLg=ntse-T!"

提示

  • 1 <= s.length <= 100

  • s 仅由 ASCII 值在范围 [33, 122] 的字符组成

  • s 不含 '\"' 或 '\\'

class Solution {
public:
    string reverseOnlyLetters(string s) {

    }
};

代码解析:

这道题和快排的思路很类似,swap不知道有没有讲过在algorithm这个头文件里有,和我们在函数模板实现的差不多,这种常用的肯定能想起来了,像判断是不是字母等函数,想不起来可以自己写,想起来不清楚可以查文档:

class Solution {
public:
    string reverseOnlyLetters(string s) {
        int left  = 0,right = s.size() - 1;
        while(left < right)
        {
            while(left < right && !isalpha(s[left]))// 找字母,注意越界
            {
                ++left;
            }
            while(left < right && !isalpha(s[right]))
            {
                --right;
            }
            swap(s[left++],s[right--]);// 交换后往中间走,传引用,
        }
        return s;
    }
};

387. 字符串中的第一个唯一字符 - 力扣(LeetCode)

难度简单

给定一个字符串 s ,找到 它的第一个不重复的字符,并返回它的索引 。如果不存在,则返回 -1 。

示例 1:

输入: s = "leetcode"
输出: 0
示例 2:

输入: s = "loveleetcode"
输出: 2
示例 3:

输入: s = "aabb"
输出: -1

提示:

1 <= s.length <= 10^5
s 只包含小写字母

class Solution {
public:
    int firstUniqChar(string s) {
        
    }
};

解析代码:

可以暴力查找,是O(N^2),只有小写字母,可以用计数排序的思想:

class Solution {
public:
	int firstUniqChar(string s) {
		int countArr[26] = { 0 };
		for (auto e : s)
		{
			countArr[e-'a']++;//相对映射到数组里++
		}
		for (int i = 0;i < s.size(); i++)
		{
			if (countArr[(s[i]-'a')] == 1)//从原字符串遍历字符的相对映射
			{
				return i;//第一个相对映射为1的就返回其下标
			}
		}
		return -1;//没有出现一次的,输出-1
	}
};

125. 验证回文串 - 力扣(LeetCode)

难度简单

如果在将所有大写字符转换为小写字符、并移除所有非字母数字字符之后,短语正着读和反着读都一样。则可以认为该短语是一个 回文串 。

字母和数字都属于字母数字字符。

给你一个字符串 s,如果它是 回文串 ,返回 true ;否则,返回 false 

示例 1:

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

示例 2:

输入:s = "race a car"
输出:false
解释:"raceacar" 不是回文串。

示例 3:

输入:s = " "
输出:true
解释:在移除非字母数字字符之后,s 是一个空字符串 "" 。
由于空字符串正着反着读都一样,所以是回文串。

提示:

  • 1 <= s.length <= 2 * 10^5

  • s 仅由可打印的 ASCII 字符组成

class Solution {
public:
    bool isPalindrome(string s) {

    }
};

代码解析:

 此题和快排思路类似,从两边找字符,判断是否相等,这题可能刚看会有其它思路,但把全部大写字母转成小写字母,或者反过来都是很方便的,动手动手:

 

class Solution {
public:
    bool isPalindrome(string s) {
        for(auto& e : s)
        {
            e = tolower(e);// 如果是大写就转小写,不是大写就不处理
        }
        int left = 0,right = s.size() - 1;
        while(left < right )//找字母数字字符后比较
        {
            while(left < right && !isalpha(s[left]) && !isdigit(s[left]))
            {
                left++;
            }
            while(left < right && !isalpha(s[right]) && !isdigit(s[right]))
            {
                right--;
            }
            if(s[left] != s[right])
            {
                return false;
            }
            else
            {
                left++;
                right--;
            }
        }
        return true;
    }
};

344. 反转字符串 - 力扣(LeetCode)

难度简单

编写一个函数,其作用是将输入的字符串反转过来。输入字符串以字符数组 s 的形式给出。

不要给另外的数组分配额外的空间,

你必须原地修改输入数组、使用 O(1) 的额外空间解决这一问题。

示例 1:

输入:s = ["h","e","l","l","o"]
输出:["o","l","l","e","h"]

示例 2:

输入:s = ["H","a","n","n","a","h"]
输出:["h","a","n","n","a","H"]

提示:

  • 1 <= s.length <= 10^5

  • s[i] 都是 ASCII 码表中的可打印字符

class Solution {
public:
    void reverseString(vector<char>& s) {

    }
};

解析代码:

可以说我们以前都实现过了,就是这里变成了vector,

这里的vector就是一个存char类型的数组,我们收尾交换,进行翻转:

class Solution {
public:
    void reverseString(vector<char>& s) {
        int left = 0,right = s.size() - 1;
        while(left < right)
        {
            swap(s[left++],s[right--]);
        }
    }
};

541. 反转字符串 II - 力扣(LeetCode)

难度简单

给定一个字符串 s 和一个整数 k,从字符串开头算起,每计数至 2k 个字符,

就反转这 2k 字符中的前 k 个字符。

  • 如果剩余字符少于 k 个,则将剩余字符全部反转。

  • 如果剩余字符小于 2k 但大于或等于 k 个,则反转前 k 个字符,其余字符保持原样。

示例 1:

输入:s = "abcdefg", k = 2
输出:"bacdfeg"

示例 2:

输入:s = "abcd", k = 2
输出:"bacd"

提示:

  • 1 <= s.length <= 10^4

  • s 仅由小写英文组成

  • 1 <= k <= 10^4

class Solution {
public:
    string reverseStr(string s, int k) {

    }
};

解析代码:

题目确实有点难懂,人话:每隔k个反转k个,末尾不够k个时全部反转。

一顿试错后的代码:

class Solution {
public:
    void reverseString(string& s,int left,int right) {
        while(left < right)
        {
            swap(s[left++],s[right--]);
        }
    }
    string reverseStr(string s, int k) {
        for(size_t i = 0; i < s.size(); i += 2*k)
        {
            if(i + k > s.size())
            {
                reverseString(s,i,s.size() - 1);
            }
            else
            {
                reverseString(s,i,i + k - 1);
            }
        }
        return s;
    }
};

还可以用官方库里面的左闭右开(上面实现的是左闭右闭)的reverse函数:

class Solution {
public:
    void reverseString(string& s,int left,int right) {
        while(left < right)
        {
            swap(s[left++],s[right--]);
        }
    }
    string reverseStr(string s, int k) {
        for(size_t i = 0; i < s.size(); i += 2*k)
        {
            if(i + k > s.size())
            {
                //reverseString(s,i,s.size() - 1);
                reverse(&s[i],&s[s.size()]);
            }
            else
            {
                //reverseString(s,i,i + k - 1);
                reverse(&s[i],&s[i + k]);
            }
        }
        return s;
    }
};

557. 反转字符串中的单词 III - 力扣(LeetCode)

难度简单

给定一个字符串 s ,你需要反转字符串中每个单词的字符顺序,

同时仍保留空格和单词的初始顺序。

示例 1:

输入:s = "Let's take LeetCode contest"
输出:"s'teL ekat edoCteeL tsetnoc"

示例 2:

输入: s = "God Ding"
输出:"doG gniD"

提示:

  • 1 <= s.length <= 5 * 10^4

  • s 包含可打印的 ASCII 字符。

  • s 不包含任何开头或结尾空格。

  • s 里 至少 有一个词。

  • s 中的所有单词都用一个空格隔开。

class Solution {
public:
    string reverseWords(string s) {

    }
};

解析代码:

(类似双指针的思想:)

class Solution {
public:
    string reverseWords(string s) {
        size_t left = 0,right = 0;
        while(left < s.size())
        {
            while(right < s.size() && s[right] != ' ')// 找空格/结尾,要先判断结尾,防止越界访问
            {
                ++right;
            }
            reverse(&s[left],&s[right]);// 注意是左闭右开(反正我是服了)
            ++right;//跳过空格,进行下一次判断
            left = right;
        }
        return s;
    }
};

43. 字符串相乘 - 力扣(LeetCode)

难度中等

给定两个以字符串形式表示的非负整数 num1 和 num2,返回 num1 和 num2 的乘积,

它们的乘积也表示为字符串形式。

注意:不能使用任何内置的 BigInteger 库或直接将输入转换为整数。

示例 1:

输入: num1 = "2", num2 = "3"
输出: "6"

示例 2:

输入: num1 = "123", num2 = "456"
输出: "56088"

提示:

  • 1 <= num1.length, num2.length <= 200

  • num1 和 num2 只能由数字组成。

  • num1 和 num2 都不包含任何前导零,除了数字0本身。

class Solution {
public:
    string multiply(string num1, string num2) {

    }
};

解析代码:

这题有点难就看题解了,这里用方法二:

class Solution {
public:
	string multiply(string num1, string num2) {
		int n = num1.size(), m = num2.size();
		vector<int> v(n + m, 0);//开n+m个0
		for (int i = 0; i < n; ++i)
		{
			for (int j = 0; j < m; ++j)
			{
				int a = num1[n - i - 1] - '0';
				int b = num2[m - j - 1] - '0';
				v[i + j] += a * b;
			}
		}
		for (int i = 0, carry = 0; i < v.size();++i)//carry进位
		{
			v[i] += carry;
			carry = v[i] / 10;
			v[i] %= 10;
		}
		string ret;
		for (int i = v.size() - 1;i >= 0;--i)
		{
			if (ret.empty() && v[i] == 0)//如果ret是空的,并且v[i] == 0,就是前导0的情况
			{
				continue;
			}
			ret += (v[i] + '0');
		}
		return ret.empty() ? "0" : ret;//如果是空串就返回0,也可以在开头判断
	}
};

本章完。

下一篇:模拟实现string,深拷贝浅拷贝,拷贝构造和赋值重载的传统写法和现代写法。

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

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

相关文章

ESP32 智能手表软件设计,具有多个表盘、心率传感器、指南针和游戏

ESP32 智能手表 GUI 导航 整个 GUI 的设计方式使我们可以使用单个按钮浏览每个选项。我们可以使用短按和长按来浏览它们。您可以在下图中找到整个 GUI 流程。蓝线表示单击/短按,而绿线表示长按。在时间设置和设置菜单中,您可以浏览每个选项或使用短时钟归档。选择该选项并使用…

搭建简单的HTTP服务器(Nodejs) - 内网穿透公网远程访问

文章目录 前言1.安装Node.js环境2.创建node.js服务3. 访问node.js 服务4.内网穿透4.1 安装配置cpolar内网穿透4.2 创建隧道映射本地端口 5.固定公网地址 转载自cpolar内网穿透的文章&#xff1a;使用Nodejs搭建HTTP服务&#xff0c;并实现公网远程访问「内网穿透」 前言 Node.…

【工业控制系统】工业控制系统安全简介第 2 部分

介绍 Purdue Enterprise Reference Architecture (PERA)、其他参考模型和安全 ICS 架构的最佳实践。 安全 ICS 架构的 Purdue 模型和最佳实践 在本系列的第一部分中&#xff0c;我们回顾了工业控制系统 (ICS) 的独特沿袭&#xff0c;并介绍了保护 ICS 的一些挑战。在第二部分中…

初识滴滴交易策略之二:司乘匹配

‍ 前文&#xff08;初识滴滴交易策略之一&#xff1a;交易市场)整体介绍了交易市场的定义、特点、技术特点和技术领域。在交易市场中&#xff0c;市场交易撮合——通常称之为“派单”——无疑是最重要的环节&#xff0c;以下将介绍滴滴交易市场中的司乘匹配技术。 对滴滴来说&…

全球523所高校,10425人共同学习,这所高校排第一!

Datawhale学习 总结&#xff1a;四月AIGC组队学习 在公众号回复“五月”可以提前进大模型应用交流群了&#xff0c;探索大模型的产品应用。回复“AIGC”&#xff0c;可以进AIGC交流群&#xff0c;用AIGC工具为自己打工。五月组队学习这周会在群内分享。 五月组队学习预告 全球…

2023年国内CDGA/CDGP数据治理认证考试报名入口

DAMA认证为数据管理专业人士提供职业目标晋升规划&#xff0c;彰显了职业发展里程碑及发展阶梯定义&#xff0c;帮助数据管理从业人士获得企业数字化转型战略下的必备职业能力&#xff0c;促进开展工作实践应用及实际问题解决&#xff0c;形成企业所需的新数字经济下的核心职业…

DNDC模型三:气象数据、土地数据、土壤数据、区域数据制备

查看原文>>>最新DNDC模型在土地利用变化、未来气候变化下的建模方法及温室气体时空动态模拟实践技术应用 由于全球变暖、大气中温室气体浓度逐年增加等问题的出现&#xff0c;“双碳”行动特别是碳中和已经在世界范围形成广泛影响。国家领导人在多次重要会议上讲到&a…

Python长时间序列遥感数据处理及在全球变化、物候提取、植被变绿与固碳分析、生物量估算与趋势分析

植被是陆地生态系统中最重要的组分之一&#xff0c;也是对气候变化最敏感的组分&#xff0c;其在全球变化过程中起着重要作用&#xff0c;能够指示自然环境中的大气、水、土壤等成分的变化&#xff0c;其年际和季节性变化可以作为地球气候变化的重要指标。此外&#xff0c;由于…

第14章:触发器概述

一、触发器概述 1.开发场景 有2个相互关联的表&#xff0c;商品信息和库存信息表。在添加一条新商品记录时&#xff0c;为了保证数据完整性&#xff0c;在库存表添加一条库存记录。 把两个关联操作步骤写到程序里面&#xff0c;用事务包裹起来&#xff0c;确保两个操作成为一…

Qt6之默认取消MySQL支持?

说明&#xff1a;本篇不是讨论qt怎么使用MySQL&#xff0c;这类的文章一搜一大堆。 一、结论 Qt6开始确实默认取消了对MySQL的支持&#xff0c;用户需自行编译生成MySQL的驱动DLL库。 首先不是qt增加使用门槛是风向变了&#xff0c;而是自从Oracle 收购MySQL后对其进行了商业化…

LC-1377. T 秒后青蛙的位置(DFS、BFS)

1377. T 秒后青蛙的位置 难度困难57 给你一棵由 n 个顶点组成的无向树&#xff0c;顶点编号从 1 到 n。青蛙从 顶点 1 开始起跳。规则如下&#xff1a; 在一秒内&#xff0c;青蛙从它所在的当前顶点跳到另一个 未访问 过的顶点&#xff08;如果它们直接相连&#xff09;。青…

一键呼叫可视对讲用于路灯杆

城市建设进入新时代&#xff0c;各种智慧化设施应运而生。路灯杆一键呼叫可视对讲系统可以实现智能安防、信息传递等多种功能&#xff0c;成为城市智慧化的重要组成部分。 1. 系统介绍 路灯杆一键呼叫可视对讲系统由路灯杆、摄像头、语音呼叫器等组成。当市民需要求助或报警时…

大数据开发之Hive案例篇5- count(distinct) 优化一例

文章目录 一. 问题描述二. 解决方案2.1 调整reduce个数2.2 SQL改写 一. 问题描述 需求: 卡在了reduce&#xff0c;只有一个reduce MR job卡在了最后一个reduce&#xff0c;任务迟迟未运行成功 二. 解决方案 2.1 调整reduce个数 一般一个reduce处理的数据是1G&#xff0c…

【Dubbo核心 详解四】Dubbo服务提供者的详解

✅创作者&#xff1a;陈书予 &#x1f389;个人主页&#xff1a;陈书予的个人主页 &#x1f341;陈书予的个人社区&#xff0c;欢迎你的加入: 陈书予的社区 &#x1f31f;专栏地址: Dubbo核心详解(附代码示例) 文章目录 引言一、服务提供者1.1 服务提供者介绍Dubbo 服务提供者启…

NPDP|产品经理的硬实力体现在哪里?

在企业里&#xff0c;产品经理是一个具有综合职能的职位&#xff0c;其工作的范围可以说已经遍及到了公司的每个角落其接触的人员也涉及公司几乎所有的部门。 产品经理是产品品牌塑造者、更是营销骨干&#xff0c;是一套完善的营销运作制度&#xff0c;更是博大精深的营销操作…

git clone 报错10054,解决方法

使用git clone下载工程时&#xff0c;报错提示如下&#xff1a; fatal: unable to access https://github.com/deozhang/GaoZhongShuXue.git/: OpenSSL SSL_read: Connection was reset, errno 10054 报错提示的代码是10054&#xff0c;根据提示和网上搜索结果&#xff0c;可以…

Ae:跟踪运动

使用跟踪器 Tracker面板的跟踪运动 Track Motion功能&#xff0c;可通过手动添加和设置跟踪点来跟踪对象的运动&#xff0c;并能将获得的跟踪数据应用于其它对象。 Ae菜单&#xff1a;窗口/跟踪器 Tracker 点击跟踪器面板上的“跟踪运动”按钮&#xff0c;会为图层添加“动态跟…

Charles使用教程【简易版】

Charles抓包教程 1、电脑安装charles 2、电脑打开charles后安装root证书 3、电脑信任证书 4、手机连接与电脑同一wifi 5、设置手机代理 wlan设置中将当前 wifi 的代理改成手动&#xff0c;主机名填电脑 ip&#xff0c;端口填8888 此时如果当前手机是第一次被你的电脑设备代理或…

【JavaSE】Java基础语法(四)

文章目录 &#x1f37c;1. 循环细节&#x1f962;1.1 循环语句-dowhile循环&#x1f962;1.2 三种循环的区别&#x1f962;1.3 跳转控制语句 &#x1f37c;2. Random&#x1f962;2.1 Random产生随机数&#x1f962;2.2 Random练习-猜数字 &#x1f37c;1. 循环细节 &#x1f…

[资料分享]基于单片机防酒驾酒精检测报警系统装置设计、基于数字电路演讲计时protues仿真设计

基于单片机防酒驾酒精检测报警系统装置设计 一、说明 通过MQ3传感器检测酒精浓度&#xff0c;信号由ADCO832进行处理模数转化再到单片机进行处理&#xff0c;当检测到浓度超过“酒驾”报警值时&#xff0c;红灯亮起&#xff0c;当检测到浓度超过“醉驾”报警值时&#xff0c;…