【字符串】【双指针】1、仅仅反转字母+2、回文子串+ 3、最长回文子串+4、验证回文串+5、反转字符串中的单词

今天依旧是字符串!2道简单+3道中等

1、仅仅反转字母(难度:简单)

在这里插入图片描述
在这里插入图片描述

该题对应力扣网址

错误做法

一开始是“原始”思路,交了之后果然不对,错误的思路我也就不解释了。

class Solution {
public:string reverseOnlyLetters(string s) {int n=s.length();int i,temp;for(i=0;i<n/2;i++){if((s[i]>='a' && s[i]<='z') || (s[i]>='A' && s[i]<='Z')){temp=s[i];s[i]=s[n-i-1];s[n-i-1]=temp;}}return s;}
};

AC代码

想了一下还是用前几天刚学过的双指针就行(真香了)

class Solution {
public:bool alphabet(char ch){if((ch>='a' && ch<='z') || (ch>='A' && ch<='Z')){return true;}return false;}string reverseOnlyLetters(string s) {int n=s.length();int left=0,right=n-1,temp;while(left<=right){if(alphabet(s[left]) && alphabet(s[right])){temp=s[left];s[left]=s[right];s[right]=temp;left++;right--;}else if(!alphabet(s[left]) && alphabet(s[right])){while(!alphabet(s[left])){left++;}temp=s[left];s[left]=s[right];s[right]=temp;left++;right--;}else if(alphabet(s[left]) && !alphabet(s[right])){while(!alphabet(s[right])){right--;}temp=s[left];s[left]=s[right];s[right]=temp;left++;right--;}else{left++;right--;}}return s;}
};

2、回文子串(难度:中等)

在这里插入图片描述
该题对应力扣网址

AC代码

一开始没啥思路,只有笨方法,(觉得写了肯定也超时) 大概看了题解推荐的方法,其中这个双指针中心点的方法还是挺简单的,dp那个方法没看懂,等做dp类型的时候再说。
这道题就是和普通的判断是否是回文串反过来了,判断回文串,一般都是从两边往中间,双指针。
这道题是找字符串里有多少回文串,是从中心点往两边双指针
思路:
中心点分两类:一个中心点、两个中心点
然后从中间往两边看两边对应位置的字符是否一样

class Solution {
public:int countSubstrings(string s) {int n = s.length();int i,j,k;int left,right;int num = 0;//遍历字符串里每个字符for(i=0;i<n;i++){//确定一个或两个中心点for(j=0;j<=1;j++){left=i;right=i+j;if(j==1){if(s[left]!=s[right]){continue;}}while(left>=0 && right<=n && s[left--]==s[right++]){num++;}}}return num;}
};

3、最长回文子串(难度:中等)

在这里插入图片描述
该题对应力扣网址

AC代码

没啥,和上一题的思路基本一致

class Solution {
public:static bool cmp(const pair<string,int> &a,const pair<string,int> &b){return a.second>b.second;}string longestPalindrome(string s) {int i,j,k,l,r,count;int n = s.length();vector <pair<string,int>> str;for(i=0;i<n;i++){for(j=0;j<=1;j++){count=0;l=i;r=i+j;if(j==1){if(s[l]!=s[r]){continue;}}while(l>=0 && r<=n-1 &&l<=r && s[l--]==s[r++]){count++;}if(j==1){str.push_back({s.substr(i-count+1,count*2), count*2});}if(j==0){str.push_back({s.substr(i-count+1,(count-1)*2+1), (count-1)*2+1});}}}sort(str.begin(),str.end(),cmp);return str[0].first;}
};

4、验证回文串(难度:简单)

在这里插入图片描述

该题对应力扣网址

AC代码

没啥说的

class Solution {
public://判断是不是大写字母bool daxie(char ch){if(ch>='A' && ch<='Z'){return true;}return false;}//判断是不是小写字母bool xiaoxie(char ch){if(ch>='a' && ch<='z'){return true;}return false;}//判断是不是数字bool shuzi(char ch){if(ch>='0' && ch<='9'){return true;}return false;}//判断是不是回文串bool huiwen(string str){int n = str.length();int l=0,r=n-1;while(l<=r){if(str[l]==str[r]){l++;r--;}else{return false;}}return true;}bool isPalindrome(string s) {int i,j=0,k;int n = s.length();string str="";for(i=0;i<n;i++){if(daxie(s[i])){str+=s[i]+32;}else if(xiaoxie(s[i])){str+=s[i];}else if(shuzi(s[i])){str+=s[i];}}return huiwen(str);}
};

5、反转字符串中的单词(难度:中等)

在这里插入图片描述
该题对应力扣网址

AC代码

没看题解,思路依旧是双指针,r指针从后往前,遍历完一个单词之后,l指针从前往后,遍历这个单词,并加入到新的字符串str中。
主要有四种情况,按照代码的顺序依次是:
1、单词左面第一个空格
2、字符串第一个字符且该字符不是空格
3、存在连续的多个空格
4、单词中的字符
注意:写代码的时候,不注意的话,数组容易溢出,建议在判断条件里把边界放在前面,例如while(r>=0 && s[r]==' ')

class Solution {
public:string reverseWords(string s) {int i,j,k,count=0;int l,r;string str="";r=s.length()-1;while(r>=0){if(s[r]==' ' && s[r+1]!=' ' && r+1<=s.length()-1){l=r;cout<<r<<" "<<count<<endl;while(count>0){l++;str+=s[l];count--;}count=0;str+=' ';}else if(r==0 && s[r]!=' '){l=r;while(count>=0){str+=s[l];l++;count--;}count=0;}//存在多个空格else if(s[r]==' '){while( r>=0 && s[r]==' '){r--;}continue;}else{count++;}r--;}int n=str.length()-1;//把多余的最后的空格删掉if(str[n]==' '){str.pop_back();}return str;}
};

中间出去玩儿了两天,今天才补上,慢慢来吧

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

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

相关文章

Debezium系列之:Mysql和SQLServer数据库字段类型覆盖测试

Debezium系列之:Mysql和SQLServer数据库字段类型覆盖测试 一、需求背景二、类型对比三、完整流程三、Mysql数据库全字段类型覆盖测试四、SQLServer数据库字段类型覆盖测试一、需求背景 Debezium版本升级迭代,要做字段类型测试,确保版本间字段类型的差异下游能够自动适应,或…

在android系统中应用java反射

在Android系统中使用Java反射是一种强大的技术&#xff0c;它允许我们在运行时检查和修改代码、类和对象的行为。以下是三个在Android开发中使用Java反射的经典实践案例&#xff0c;并附上了相应的编程代码示例。 案例一&#xff1a;动态调用私有方法 假设我们有一个包含私有…

高考未上本科线,大专不是唯一归宿

高考&#xff0c;作为人生中的一次重要考试&#xff0c;其结果往往牵动着无数家庭的心。然而&#xff0c;当高考成绩未能达到本科线时&#xff0c;是否就意味着大专是唯一的选择呢&#xff1f;其实不然&#xff0c;现代教育体系的多样化为我们提供了更多的可能性&#xff0c;其…

林奇的选股方法之一,从低迷中寻找卓越

在《战胜华尔街》的第十章《沙漠之花&#xff1a;低迷行业中的卓越公司》中&#xff0c;林奇指出“必过一个行业太热门了&#xff0c;竞争者拼命进入&#xff0c;竞争就会激烈到谁也赚不到什么钱”&#xff0c;相反&#xff0c;“低迷行业成长缓慢&#xff0c;经营不善的弱者一…

12.日志

1.日志记录 日志记录将应用程序运行时的关键信息写入日志文件或者输出到控制台 方便问题排查:日志记录提供了有关问题的关键信息,可以快速定位和修复错误. 系统监控: 通过记录查看应用程序的运行状态,资源使用和性能指标, 运行分析: 允许我们跟踪应用程序的执行流程和事件,以便…

openinstall拥抱鸿蒙生态,SDK全面适配HarmonyOS NEXT

作为国内领先的App渠道统计与深度链接服务商&#xff0c;openinstall持续推动鸿蒙生态建设&#xff0c;近日正式发布openinstall HarmonyOS SDK&#xff0c;并成功入驻鸿蒙生态伙伴SDK专区&#xff0c;成为华为鸿蒙生态的合作伙伴&#xff0c;为鸿蒙应用开发者带来安全合规、高…

ONLYOFFICE 桌面编辑器 8.1华丽登场

简介&#xff1a;全新ONLYOFFICE 桌面编辑器 8.1解锁全新PDF编辑、幻灯片优化与本地化体验&#xff0c;立即下载&#xff01; 前言&#xff1a;在数字化时代&#xff0c;高效的办公协作工具是企业和个人不可或缺的利器。ONLYOFFICE&#xff0c;作为一款功能强大的云端和桌面办公…

数据结构-图的存储结构-邻接矩阵

图的结构十分复杂&#xff0c;不仅各个结点的度不同&#xff0c;各个顶点之间的路径也不尽相同。但是图的主要组成部分比较清晰&#xff0c;分为顶点信息和边或者弧的信息。 邻接矩阵 邻接矩阵就是用一维数组存储图中顶点的信息&#xff0c;用一个二维数组表示图中各个顶点之间…

java读取csv文件转换成实体类

java读取csv文件转换成实体类 java读取csv文件转换成实体类 java读取csv文件转换成实体类1、需求:2、使用opencsv实现2.1 添加OpenCSV依赖到你的项目中(如果使用Maven):2.2 定义你的实体类:2.3 创建一个CSV工具类,根据需要指定字符集编码格式2.4 编写测试类,读取CSV文件…

uni-app与原生插件混合开发调试1-环境准备

uni-app与原生插件混合开发调试系列文章分为3篇&#xff0c;分别详细讲了《环境准备》、《搭建uni-app本地开发调试环境》和《安卓原生插件开发调试和打包》&#xff0c;3篇文章完整详细地介绍了“从环境安装配置到本地开发调试到原生插件打包”整个流程。 相关名词和概念解释…

FuTalk设计周刊-Vol.026

&#x1f525;&#x1f525;AI漫谈 热点捕手&#x1f525;&#x1f525; 1、Hotshot-XL AI文本转GIF Hotshot-XL 是一种 AI 文本转 GIF 模型&#xff0c;经过训练可与Stable Diffusion XL一起使用。能够使用任何现有或新微调的 SDXL 模型制作 GIF。 网页体验 网页http://htt…

GET、POST介绍

POST地址构成 如&#xff1a;http://192.123.143.18:9666/image /predict 组成如下&#xff1a; http&#xff1a;使用http协议 IP地址/域名&#xff1a;192.123.143.18 port端口&#xff1a;9666&#xff08;http默认80端口、https默认443&#xff09; 服务名称&#xff1a;i…

智能体实战:开发一个集成国内AI平台的GPTs,自媒体高效智能助手

文章目录 一&#xff0c;什么是GPTs二&#xff0c;开发GPTs1&#xff0c;目标2&#xff0c;开发2.1 打开 GPTS&#xff1a;https://chat.openai.com/gpts2.2 点击 Create 创建一个自己的智能体 2.3 配置GPTs2.4 配置外挂工具2.4.1 配置Authentication-授权2.4.1.1 生成语聚AI的…

用FFmpeg合并音频和视频

使用FFmpeg合并音频和视频是一个相对直接的过程。可以通过以下一些基本的步骤和命令示例完成这个任务&#xff1a; 安装FFmpeg&#xff1a;首先&#xff0c;确保你的系统中已经安装了FFmpeg。你可以从[FFmpeg官网](Download FFmpeg)下载并安装它。 准备素材&#xff1a;确保你…

服务器重装系统后,远程ssh需要修改的内容

前提 首先实验室服务器内部是搭了内网的&#xff0c;所以有固定的IP,IP是和网卡的MAC地址有关的&#xff0c;所以和系统没有关系&#xff0c;所以更换了系统不会影响IP的。 修改内容 1、首先需要安装 SSH sudo apt install openssh-server2、之后需要修改ssh的配置参数 打…

Oracle day13

/*CREATE TABLE f726( ID number, Type VARCHAR2(20), MasterID number, Amount number ); INSERT INTO f726 VALUES (1,直接合同,NULL,5000); INSERT INTO f726 VALUES (2,补充合同,1,1000); INSERT INTO f726 VALUES (3,补充合同,1,500); INSERT INTO f726 VALUES (4,直接合同…

itsdangerous,一个强大的 Python 库!

更多资料获取 &#x1f4da; 个人网站&#xff1a;ipengtao.com 大家好&#xff0c;今天为大家分享一个强大的 Python 库 - itsdangerous。 Github地址&#xff1a;https://github.com/pallets/itsdangerous 在Web应用开发中&#xff0c;数据的安全传输和存储是非常重要的。P…

服务器部署—虚拟机安装nginx并部署web网页

该篇博客用于讲解Linux的Centos7发行版中如何通过Linux安装Nginx&#xff0c;然后将静态页面部署到Nginx中&#xff0c;通过浏览器访问。 非常适用于新手小白学习项目部署相关的知识。建议收藏&#xff01;&#xff01;&#xff01; 需要大家提前准备好虚拟机和CentOS7操作系统…

python API自动化(基于Flask搭建MockServer)

接口Mock的理念与实战场景: 什么是Mock: 在接口中&#xff0c;"mock"通常是指创建一个模拟对象来代替实际的依赖项&#xff0c;以便进行单元测试。当一个类或方法依赖于其他类或组件时&#xff0c;为了测试这个类或方法的功能&#xff0c;我们可以使用模拟对象来替代…

企业级-生成PDF移除异常空白页

作者&#xff1a;fyupeng 技术专栏&#xff1a;☞ https://github.com/fyupeng 项目地址&#xff1a;☞ https://github.com/fyupeng/distributed-blog-system-api 留给读者 咱们又见面了&#xff0c;本期带给大家什么&#xff0c;请往下看&#xff0c;绝对是干货&#xff01; …