萌新刷题1

文章介绍了如何高效地验证一个字符串是否为回文,通过从两端向中间比较字符并利用反转函数来检查子串是否为回文,避免了不必要的字符删除,实现了优化的时间复杂度解决方案。
摘要由CSDN通过智能技术生成

力扣习题记录

1.验证回文字符串2
思路:开始准备把每一个都删除了,看看是否是回文串,但是这样的时间复杂度很高,于是思考有没有别的办法。
后来采用,从两端到中间的方式,low与high记录当前字符串字符的位置,然后开始比较,如果当前的字符不一样,那么判断(low,high-1)与(low+1,high)这个位置之间的字符串是否为回文串,如果是的就返回TRUE。
2.采用的函数
(string反转函数)
#include 头文件
reverse函数反转string,用来反转容器里面的元素。
reverse (迭代器1,迭代器2) 前闭后开
(string取子串函数)
在这里插入图片描述3.代码实现

class Solution {
public:
   bool palindrome(string a,int low,int high)
       {
            string zichuang=a.substr(low, high-low+1) ;
            string temp=zichuang;
            reverse(temp.begin(),temp.end());
             if(temp==zichuang) return true;
             return false;
       }
       
    bool validPalindrome(string s) {
        int length=s.size();
        int low=0,high=length-1;
        while(low<=high)
        {
                 if(s[low]!=s[high])
                 {
                     return palindrome(s,low,high-1)|| palindrome(s,low+1,high);
                     break;
                 }
                 low++;
                 high--;
        }
        return true;
    }
};
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值