算法思想总结:字符串

news2024/11/15 11:16:49

一、最长公共前缀

. - 力扣(LeetCode)

思路1:两两比较  时间复杂度mn  实现findcomon返回两两比较后的公共前缀

class Solution {
public:
    string longestCommonPrefix(vector<string>& strs) 
    {
       //两两比较 
       string ret=strs[0];
       size_t n=strs.size();
       for(size_t i=0;i<n;++i)
          ret=findcommon(ret,strs[i]);
            return ret;
    }
    string findcommon(string&s1,string&s2)
    {
        size_t n=min(s1.size(),s2.size());
        size_t i=0;
        for(;i<n;++i)
           if(s1[i]!=s2[i]) break;
        return s1.substr(0,i);
    }
};

 思路2:统一比较  时间复杂度mn

class Solution {
public:
    string longestCommonPrefix(vector<string>& strs) 
    {
        //统一比较
        size_t m=strs.size(),n=strs[0].size();
        for(int i=0;i<n;++i)
        {
            char temp=strs[0][i];
            for(int j=0;j<m;++j)
             if(i==strs[j].size()||strs[j][i]!=temp)
              return strs[0].substr(0,i); 
        }
        return strs[0];//可能只有一个字符串
    }
};

二、最长回文子串

. - 力扣(LeetCode)

解法:中心扩展算法

1、固定一个中心点,从中心点开始往两边扩展

2、要考虑奇数长度,也要考虑偶数长度

class Solution {
public:
    string longestPalindrome(string s) 
    {
        size_t begin=0; size_t len=0;//帮助我们记录符合要求的回文子串
        //中心扩展算法
        size_t n=s.size();
        for(size_t i=0;i<n;++i)
        {
            int left=i,right=i;//考虑奇数回文串
            while(left>=0&&right<n&&s[left]==s[right]) 
            {
                --left;
                ++right;
            }
            if(right-left-1>len) 
            {
                begin=left+1;
                len=right-left-1;
            }
            //考虑偶数回文串
             left=i;right=i+1;//考虑奇数回文串
            while(left>=0&&right<n&&s[left]==s[right]) 
            {
                --left;
                ++right;
            }
            if(right-left-1>len) 
            {
                begin=left+1;
                len=right-left-1;
            }
        }
        return s.substr(begin,len);
    }
};

三、二进制求和(字符串相加)

. - 力扣(LeetCode)

解法:模拟进位相加,但是区别就是得逢2进1 ,再将最后的结果逆序。

class Solution {
public:
    string addBinary(string a, string b) {
    //模拟进位相加,但是区别就是逢2进1
    size_t n1=a.size(),n2=b.size();
    string ret;//返回   从后往前模拟进位相加
    ret.reserve(n1>n2?n1+1:n2+1);//提前开空间  减少时间消耗
    int cur1=n1-1; 
    int cur2=n2-1;
    int t=0;
    while(cur1>=0||cur2>=0||t) //可能会有进位的遗失
    {
       if(cur1>=0) t+=a[cur1--]-'0';
       if(cur2>=0) t+=b[cur2--]-'0';
        ret+=t%2+'0';
        t/=2;
    }
    reverse(ret.begin(),ret.end());//结果要反转一下
    return ret;
    }
};

 四、字符串最后一个单词的长度

字符串最后一个单词的长度_牛客题霸_牛客网

该题不能用cin>>s 因为遇到空格就会停止,所以要解决这个问题就必须用getline

而string中的rfind可以帮助我们从后往前找。

#include <iostream>
using namespace std;

int main() 
{
   string s;
   getline(cin,s);//接受一个带空格的字符串
   cout<<s.size()-1-s.rfind(" ")<<endl;
   //while(cin>>s);
   //cout<<s.size();
   return 0;
}

因为该题凑巧找的是最后一个,所以也可以直接用while(cin>>s) 最后会接受到最后一个字符串

五、仅仅翻转字母

. - 力扣(LeetCode)

       非英文字符保存在原地,而英文字母翻转,所以我们可以用双指针分别指向字符串的首尾位置,如果遇到非字母的就往中间靠,当两个指针指向的都是字母的时候,交换两个指针指向的字母即可 

class Solution {
public:
    string reverseOnlyLetters(string s)
    {
        //双指针法
          size_t begin=0;
          size_t end=s.size()-1;
          while(begin<end)
          {
              while(begin<end&&!isalpha(s[begin])) ++begin;
              while(begin<end&&!isalpha(s[end]))   --end;
              swap(s[begin],s[end]);
              ++begin;
              --end;
          }
          return s;
    }
};

六、验证回文串

. - 力扣(LeetCode)

       验证回文串,只需要用双指针指向首尾的位置,对非字母数字的直接跳过,当两个指针停下来的时候判断对应位置的字母是不是相同的。

class Solution {
public:
    bool isPalindrome(string s)
    {
      //双指针往中间靠,直到相遇则回文  
       int length=s.size();
       int left=0,right=length-1;
       while(left<right)
       {
         while(left<right&&!isalnum(s[left]))  ++left;
         while(left<right&&!isalnum(s[right])) --right;
         if(left<right)
             if(tolower(s[left])!=tolower(s[right]))
                  return false;
         ++left;
         --right;
       }
       return true;
    }
};

七、反转字符串II

. - 力扣(LeetCode)

class Solution {
public:
    string reverseStr(string s, int k)
    {
        int n=s.size();
        for(int i=0;i<n;i+=2*k)
             reverse(s.begin()+i,s.begin()+min(i+k,n));
        return s;
    }
};

需要注意的是如果i+k超过了n,就要将他修正为n。

 八、反转字符串III

双指针,始终让两个指针指向字符串中某个单词的头和尾,然后进行反转。 

class Solution {
public:
    string reverseWords(string s)
    {
          int head=0,tail=0;//双指针法
          int length=s.size();
          while(head<length)
          {
             if(s[head]!=' ')
             {
                 while(tail<length&&s[tail]!=' ')
                 ++tail;
                 reverse(s.begin()+head,s.begin()+tail);
             }
             ++tail;
             head=tail;
          }
          return s;
    }
};

 九、字符串相乘(重点)

. - 力扣(LeetCode)

class Solution {
public: //从后往前不需要处理前导0
       string multiply(string num1, string num2)
    { //高位相乘补0   处理前导0  最后处理进位
      if(num1=="0"||num2=="0") return "0";
      string ret="0";//处理返回值 方便进行相加
      int m = num1.size(), n = num2.size();
      for(int i=n-1;i>=0;--i)
      {
        string cur;
        int add=0;//处理进位
        for(int j=n-1;j>i;--j) //为了高位的补0
           cur.push_back('0');
        int y=num2[i]-'0';//取出这一位
        for(int j=m-1;j>=0;--j)
        {
            int x=num1[j]-'0';
            int product=x*y+add;
            cur.push_back(product%10+'0');
            add=product/10;//保留进位
        }
        while(add!=0)
         {
            cur.push_back(add%10+'0');
            add/=10;
         }
         reverse(cur.begin(),cur.end());
         ret= addBinary(ret, cur);
      }
       return ret;
    }

string addBinary(string a, string b) {
    //模拟进位相加,但是区别就是逢2进1
    size_t n1=a.size(),n2=b.size();
    string ret;//返回   从后往前模拟进位相加
    ret.reserve(n1>n2?n1+1:n2+1);//提前开空间  减少时间消耗
    int cur1=n1-1; 
    int cur2=n2-1;
    int t=0;
    while(cur1>=0||cur2>=0||t) //可能会有进位的遗失
    {
       if(cur1>=0) t+=a[cur1--]-'0';
       if(cur2>=0) t+=b[cur2--]-'0';
        ret+=t%10+'0';
        t/=10;
    }
    reverse(ret.begin(),ret.end());//结果要反转一下
    return ret;
    }
};

class Solution {
public:
    string multiply(string num1, string num2) 
    {
      //处理相乘问题->1、先无进位相乘 2、然后相加 3、然后处理进位  4、然后处理前导0
      size_t m=num1.size(),n=num2.size();
      //准备工作,模拟进位前将两个字符串先进行逆序
      reverse(num1.begin(),num1.end());
      reverse(num2.begin(),num2.end());
      vector<size_t> temp(m+n-1);
      for(size_t i=0;i<m;++i) //无进位相乘
        for(size_t j=0;j<n;++j) 
          temp[i+j]+=(num1[i]-'0')*(num2[j]-'0');//无进位相乘后累加
      //处理进位
      size_t cur=0,t=0;//t是进位信息
      string ret;
      ret.reserve(m+n);//优化一下,提前开空间
      while(cur<m+n-1||t) 
      {
        if(cur<m+n-1) t+=temp[cur++];
           ret+=t%10+'0';
             t/=10;
      }
      //3 处理前导0
      while(ret.size()>1&&ret.back()=='0') ret.pop_back();
      reverse(ret.begin(),ret.end());
      return ret;
    }
};

十、字符串中常用的一些接口

C语言相关:

C语言:字符函数和字符串函数-CSDN博客

 C++相关:

C++:String类的使用-CSDN博客

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

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

相关文章

2.生产者核心流程总结

目录 概述 概述 生产者核心流程总结&#xff0c;根据流程总结出生产者的调优流程及生产者修改配置的文档地址&#xff0c;有以上两点&#xff0c;即可完成生产者优化。 注意&#xff1a;下面的都是生产者环节调优的点。 一条消息经过序例化后划分至 broker 上的哪一个分区消息…

Springboot + JWT 的 Token 登录验证

目录 项目结构 一、 引入依赖 二、自定义Auth认证注解 三、 编写登录拦截器 四、定义跨域拦截器 五、 定义全局异常处理器 六、定义工具类 1. 统一错误状态码 2.统一响应类 3.Token工具类 七、 编写实体类 八、 定义控制器 1.定义登录控制器类 2 定义报错处理器 …

vscode编译环境配置-golang

1. 支持跳转 如果单测函数上方不显示run test | debug test&#xff0c;需要安装Code Debugger&#xff08;因为以前的go Test Explorer不再被维护了&#xff09; 2. 单测 指定单个用例测试 go test -v run TestXXXdlv 调试 需要安装匹配的go版本和delve版本&#xff08;如…

6.S081的Lab学习——Lab11: Network

文章目录 前言Network提示&#xff1a;实现e1000_transmit的一些提示&#xff1a;实现e1000_recv的一些提示&#xff1a; 解析 总结 前言 一个本硕双非的小菜鸡&#xff0c;备战24年秋招。打算尝试6.S081&#xff0c;将它的Lab逐一实现&#xff0c;并记录期间心酸历程。 代码下…

Go-知识测试-性能测试分析工具-benchstat

Go-知识测试-性能测试分析工具-benchstat benchmark 结果benchstat确认 benchstat 已安装确认 GOPATH 和 GOBIN将 $GOPATH/bin 添加到 PATH验证安装检查安装路径 使用 传送门&#xff1a;Go-知识测试-性能测试 benchmark 结果 benchmark 测试是实际项目中经常使用的测试方法&a…

飞凌全志T527开发板U-Boot添加自定义菜单

昨日&#xff0c;终于收到了心心念念的飞凌OK-T527开发板&#xff0c;板子很漂亮&#xff0c;外设丰富&#xff0c;性能强悍&#xff0c;T527创新性地使用了RISC-V架构的协处理器&#xff0c;后期值得研究一下异核的使用&#xff1a; 有趣的是&#xff0c;板子上电&#xff0c;…

智能制造 v3.13.16 发布,ERP、MES 更新

智能制造一体化管理系统 [SpringBoot2 - 快速开发平台]&#xff0c;适用于制造业、建筑业、汽车行业、互联网、教育、政府机关等机构的管理。包含文件在线操作、工作日志、多班次考勤、CRM、ERP 进销存、项目管理、EHR、拖拽式生成问卷、日程、笔记、工作计划、行政办公、薪资模…

0.单片机工作原理

文章目录 最小系统 单片机芯片 时钟电路 复位电路 电源 最小系统 单片机芯片 本次51单片机的芯片为&#xff1a;STC89C52 Flash(闪存)程序存储器&#xff1a;存储程序的空间 SRAM&#xff1a;数据存储器&#xff0c;可用于存放程序执行的中间结果和过程数据 DPTR&#xff1a;…

某客户报表系统Oracle数据库挂起问题分析处理

某客户报表系统Oracle数据库挂起问题分析处理 一、概要 某客户报表系统Oracle数据库在3月5号、6号均出现一节点实例短暂挂起现象&#xff0c;挂起现象有两种&#xff0c;第一是普通用户不能登录数据库&#xff0c;第二是sys用户可以登录数据库&#xff0c;但是做简单的select查…

C判断一个点在三角形上

背景 鼠标操作时&#xff0c;经常要判断是否命中显示控件&#xff0c;特开发此算法快速判断。 原理 三角形三等分点定理是指在任意三角形ABC中&#xff0c;可以找到三个点D、E和F&#xff0c;使得线段AD、BE和CF均等分三角形ABC。 这意味着三个等分点分别位于三个边界上&…

数据湖表格式 Hudi/Iceberg/DeltaLake/Paimon TPCDS 性能对比(Spark 引擎)

当前&#xff0c;业界流行的集中数据湖表格式 Hudi/Iceberg/DeltaLake&#xff0c;和最近出现并且在国内比较火的 Paimon。我们现在看到的很多是针对流处理场景的读写性能测试&#xff0c;那么本篇文章我们将回归到大数据最基础的场景&#xff0c;对海量数据的批处理查询。本文…

具身大模型研究综述

源自&#xff1a;哈工大SCIR 作者&#xff1a;陈一帆&#xff0c;张宇驰&#xff0c;孙楚芮&#xff0c;冯怀绪&#xff0c;宋浩&#xff0c;王寄哲 指导老师&#xff1a;张伟男 注&#xff1a;若出现无法显示完全的情况&#xff0c;可 V 搜索“人工智能技术与咨询”查看完整…

什么叫图像的双边滤波,并附利用OpenCV和MATLB实现双边滤波的代码

双边滤波&#xff08;Bilateral Filtering&#xff09;是一种在图像处理中常用的非线性滤波技术&#xff0c;主要用于去噪和保边。它在空间域和像素值域上同时进行加权&#xff0c;既考虑了像素之间的空间距离&#xff0c;也考虑了像素值之间的相似度&#xff0c;从而能够有效地…

赛氪网荣获2024年中国高校计算机教育大会合作伙伴荣誉

2024年7月13日&#xff0c;在黑龙江哈尔滨召开的“2024年中国高校计算机教育大会&#xff08;CCEC2024&#xff09;”&#xff0c;环球赛乐&#xff08;北京&#xff09;科技有限公司(以下简称”赛氪网“)凭借其在高等教育与科技创新领域的卓越贡献&#xff0c;荣幸地获得了本次…

SpringBoot详细解析

1.什么是springboot springboot也是spring公司开发的一款框架。为了简化spring项目的初始化搭建的。那么spring对应springboot有什么缺点呢&#xff1f; spring项目搭建的缺点: 配置麻烦依赖tomcat启动慢 2.springboot的特点 自动配置 Spring Boot的自动配置是一个运行时&…

Docker之在外执行docker内部命令(十一)

简介: CSDN博客专家,专注Android/Linux系统,分享多mic语音方案、音视频、编解码等技术,与大家一起成长! 优质专栏:Audio工程师进阶系列【原创干货持续更新中……】🚀 优质专栏:多媒体系统工程师系列【原创干货持续更新中……】🚀 优质视频课程:AAOS车载系统+AOSP…

react + redux 状态管理操作

目录 1 概念2 Redux 安装3 创建子模块并导入4 中间件为 react 注入 store5 在组件中使用 store 数据6 修改 store 数据7 提交 action 传参8 异步状态操作9 redux 调试工具 1 概念 Redux 是一个全局状态管理的 JS 库 2 Redux 安装 在react中使用redux&#xff0c;官方要求安…

「网络通信」HTTP 协议

HTTP &#x1f349;简介&#x1f349;抓包工具&#x1f349;报文结构&#x1f34c;请求&#x1f34c;响应&#x1f34c;URL&#x1f95d;URL encode &#x1f34c;方法&#x1f34c;报文字段&#x1f95d;Host&#x1f95d;Content-Length & Content-Type&#x1f95d;User…

Ubuntu使用K3S一分钟快速搭建K8S集群

快速入门指南 | Rancher文档 准备3台服务器 Master节点安装脚本# K3s 提供了一个安装脚本&#xff0c;可以方便的在 systemd 或 openrc 的系统上将其作为服务安装。这个脚本可以在 https://get.k3s.io 获得。要使用这种方法安装 K3s&#xff0c;只需运行以下命令&#xff1a;…

[超级详细系列]ubuntu22.04配置深度学习环境(显卡驱动+CUDA+cuDNN+Pytorch)--[3]安装cuDNN与Pytorch

本次配置过程的三篇博文分享分别为为&#xff1a; [超级详细系列]ubuntu22.04配置深度学习环境(显卡驱动CUDAcuDNNPytorch)--[1]安装显卡驱动 [超级详细系列]ubuntu22.04配置深度学习环境(显卡驱动CUDAcuDNNPytorch)--[2]安装Anaconda与CUDA [超级详细系列]ubuntu22.04配置深…