【算法】字符串

个人主页 : zxctscl
如有转载请先通知

题目

  • 1. 14. 最长公共前缀
    • 1.1 分析
    • 1.2 代码
  • 2. 5. 最长回文子串
    • 2.1 分析
    • 2.2 代码
  • 3. 67. 二进制求和
    • 3.1 分析
    • 3.2 代码
  • 4. 43. 字符串相乘
    • 4.1 分析
    • 4.2 代码

1. 14. 最长公共前缀

在这里插入图片描述

1.1 分析

从第一个字符串开始两两比较,把比较相同的字符部分更新到一个存放目前相同字符的ret中,然后把ret继续向后面的字符串比较,继续更新ret就行。得注意一下,如果在比较中长度超过了那两个字符中叫小的一个,那么就这组比较就结束,换下一组来继续比较。
在这里插入图片描述

1.2 代码

class Solution {
public:
    string longestCommonPrefix(vector<string>& strs) {
     string ret=strs[0];
     for(int i=1;i<strs.size();i++)
     {
       int j=0;
       while(j<min(ret.size(),strs[i].size())&&ret[j]==strs[i][j])j++;
       ret= ret.substr(0,j);
     }
     return ret;
    }    
    
};

2. 5. 最长回文子串

在这里插入图片描述

2.1 分析

回文串有个特点,就是从中间扩展它的两边是对称的。
利用中心扩展算法,固定完中间位置后,用两个指针一个在走左边,一个走右边,如果两个指针执行的字符是一样的,就移动,一直到指针指向的字符不同,或者一个指针越界。
但是这里得分两种情况,如果回文串为奇数,这个方法是正确的;但是如果为偶数,把右边的中间位置加1,此时左右指针在同时移动的时候才是正确的。
在这里插入图片描述

总之就是,先固定一个中心点,然后从中心点开始向两边扩展,注意奇数长度以及偶数长度都需要考虑。

题目要的是最长回文子串,比较一下长度之后,更新一下最大的长度。

2.2 代码

class Solution {
public:
    string longestPalindrome(string s) {
        int begin=0,len=0,n=s.size();
        for(int 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);

    }
};

3. 67. 二进制求和

在这里插入图片描述

3.1 分析

模拟的竖式计算的步骤,如果相加等于2,那么就进1,然后将这个字符取模就加到要返回的结果中,一直到两个字符串都结束。但是结果是与题目要的是相反的,所以得将得到字符串逆置。
在这里插入图片描述

3.2 代码

class Solution {
public:
    string addBinary(string a, string b) {
        string ret;
        int t=0;
        int cur1=a.size()-1,cur2=b.size()-1;
        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;
    }
};

4. 43. 字符串相乘

在这里插入图片描述

4.1 分析

如果直接按照竖式计算来的话,思路是很简单的,但是代码不容易写,得处理进位和高位相乘要补上0,还得处理前导0和计算顺序,很多细节。
所以可以换一种方式,采用无进位相加。
把每一个位置的值相乘之后,先不进位,把每次计算的结果放在一个数组里面,最后再来处理进位。
在这里插入图片描述
这里得先把两个字符串逆置,再无进位相乘相加,然后处理进位,最后处理前导0。

4.2 代码

class Solution {
public:
    string multiply(string num1, string num2) {
      int m=num1.size(),n=num2.size();
      reverse(num1.begin(),num1.end());
      reverse(num2.begin(),num2.end());
      vector<int> tmp(m+n-1);

      //无进位相乘相加
      for(int i=0;i<m;i++)
      {
        for(int j=0;j<n;j++)
        {
            tmp[i+j]+=(num1[i]-'0')*(num2[j]-'0');
        }
      }

      //处理进位
      int cur=0,t=0;
      string ret;
      while(cur<m+n-1||t!=0)
      {
        if(cur<m+n-1)t+=tmp[cur++];
        ret+=t%10+'0';
        t/=10;
      }
      
      //处理前导0
      while(ret.size()>1&&ret.back()=='0')ret.pop_back();

      reverse(ret.begin(),ret.end());
      return ret;
    }
};

有问题请指出,大家一起进步!!!

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

LlamaIndex 文档 2

文章目录 一、构建 LLM 应用构建LLM 应用的关键步骤 二、使用LLM可用的LLM使用本地LLM Prompts 三、加载数据&#xff08;提取&#xff09;Loaders1、使用 SimpleDirectoryReader 加载2、使用 LlamaHub 的 Readers3、直接创建文档 转换 Transformations1、高级转换 API2、较低级…

Unity URP PBR_Cook-Torrance模型

Cook-Torrance模型是一个微表面光照模型&#xff0c;认为物体的表面可以看作是由许多个理想的镜面反射体微小平面组成的。 单点反射镜面反射漫反射占比*漫反射 漫反射 基础色/Π 镜面反射DFG/4(NV)(NL) D代表微平面分布函数&#xff0c;描述的是法线与半角向量normalize(L…

自编译支持CUDA硬解的OPENCV和FFMPEG

1 整体思路 查阅opencv的官方文档&#xff0c;可看到有个cudacodec扩展&#xff0c;用他可方便的进行编解码。唯一麻烦的是需要自行编译opencv。 同时&#xff0c;为了考虑后续方便&#xff0c;顺手编译了FFMPEG&#xff0c;并将其与OPENCV绑定。 在之前的博文“鲲鹏主机昇腾A…

帆软查询按钮,获取组件值。

【查询】按钮增加点击事件&#xff0c;通过_g().parameterEl.getWidgetByName(‘组件名’).getValue(); 获取组件值。 js脚本示例: var bm _g().parameterEl.getWidgetByName(bm).getValue(); if(!bm || bm.length 0 ) {alert ("没有选择部门&#xff0c;查询速度会很…

解决PyCharm安装第三方库时出现“Error updating package list: Connect timed out”问题

在使用PyCharm开发Python项目时&#xff0c;有时会遇到在安装第三方库时出现“Error updating package list: Connect timed out”的错误。这通常是由于网络连接不稳定或PyPI官方源访问速度较慢导致的。为解决此类问题&#xff0c;本文将介绍以下几种策略&#xff1a; 2. 设置P…

【练习】位运算思想

&#x1f3a5; 个人主页&#xff1a;Dikz12&#x1f525;个人专栏&#xff1a;算法(Java)&#x1f4d5;格言&#xff1a;吾愚多不敏&#xff0c;而愿加学欢迎大家&#x1f44d;点赞✍评论⭐收藏 目录 1.判断字符串是否唯一 题目描述 讲解 代码实现 2.丢失的数字 题目描述…

重学Java 12 JavaBean

一、JavaBean的使用 1.标准javaBean JavaBean是Java语言编写类的一种标准规范&#xff0c;符合JavaBean的类&#xff0c;要求&#xff1a; ①类必须是具体的&#xff08;非抽象 abstract&#xff09;和公共的&#xff0c;public class 类名 ②并且具有无参数的构造方法&#x…

C#泛型,利用反射创建和普通创建泛型

泛型,利用反射创建和普通创建 反射 var input Activator.CreateInstance(typeof(Input<>).MakeGenericType(typeof(T))) as dynamic;typeof(T)这个位置可以塞入不同的类型 Activator.CreateInstance 反射动态创建实例&#xff1a; 这种方式使用 Activator.CreateIns…

Android Studio 之 Intent及其参数传递

一、Intent 显式Intent&#xff1a;通过组件名指定启动的目标组件,比如startActivity(new Intent(A.this,B.class)); 每次启动的组件只有一个~隐式Intent:不指定组件名,而指定Intent的Action,Data,或Category,当我们启动组件时, 会去匹配AndroidManifest.xml相关组件的Intent-…

《6G数据面架构研究》

目录 一、数据服务的定义二、6G数据服务驱动力及面临的挑战6G数据服务的业务驱动6G数据服务的技术驱动6G数据服务的网络内在驱动6G数据面面临的挑战 三、6G数据服务典型场景自动化网络运维用户体验提升通信感知数据服务 四、6G数据面架构研究数据面架构视图功能定义说明&#x…

在Windows上安装Go编译器并配置Golang开发环境

文章目录 1、安装Go语言编译程序1.1、下载GoLang编译器1.2、安装GoLang编译器 2、配置Golang IDE运行环境2.1、配置GO编译器2.1.1、GOROOT 概述2.1.2、GOROOT 作用2.1.2、配置 GOROOT 2.2、配置GO依赖管理2.2.1、Module管理依赖2.2.2、GOPATH 管理依赖 2.3、运行GO程序2.3.1、创…

CMake基础语法

目录 概述一、示例引入二、语法规则三、变量四、控制结构4.1 条件判断4.2 循环语句4.2.1 foreach循环4.2.2 while循环4.2.3 break、continue 五、函数六、文件操作七、环境配置7.1 设置交叉编译7.2 作用域7.3 属性 八、补充8.1 数学运算math 概述 首先我们都知道Makefile带来的…

堆放砖块-第12届蓝桥杯选拔赛Python真题精选

[导读]&#xff1a;超平老师的Scratch蓝桥杯真题解读系列在推出之后&#xff0c;受到了广大老师和家长的好评&#xff0c;非常感谢各位的认可和厚爱。作为回馈&#xff0c;超平老师计划推出《Python蓝桥杯真题解析100讲》&#xff0c;这是解读系列的第47讲。 堆放砖块&#xf…

【C语言】指针篇-初识指针(1/5)

&#x1f308;个人主页&#xff1a;是店小二呀 &#x1f308;C语言笔记专栏&#xff1a;C语言笔记 &#x1f308;C笔记专栏&#xff1a; C笔记 &#x1f308;喜欢的诗句:无人扶我青云志 我自踏雪至山巅 文章目录 **内存和地址(知识铺垫(了解即可))**如何理解编址**指针变量*…

海外短剧系统开发:引领全球短剧新潮流,打造跨文化娱乐新体验

随着全球化和互联网的快速发展&#xff0c;跨文化娱乐已经成为人们日常生活中不可或缺的一部分。海外短剧作为一种新颖、便捷的娱乐形式&#xff0c;正逐渐受到越来越多观众的喜爱。为了满足广大用户的需求&#xff0c;我们荣幸地推出全新的海外短剧系统开发方案&#xff0c;旨…

YOLOv8最新改进系列:融合DySample超轻量动态上采样算子,低延迟、高性能,目前最新上采样方法!!!遥遥领先!

YOLOv8最新改进系列&#xff1a;融合DySample超轻量动态上采样算子&#xff0c;低延迟、高性能&#xff0c;目前最新上采样方法&#xff01;&#xff01;&#xff01;遥遥领先&#xff01; DySample超轻量动态上采样算子全文戳这&#xff01;here! 详细的改进教程以及源码&am…

最新版守约者二级域名分发系统

主要功能 二级域名管理&#xff1a; 我们的系统提供全面的二级域名管理服务&#xff0c;让您轻松管理和配置二级域名。 域名分发&#xff1a;利用我们先进的域名分发技术&#xff0c;您可以自动化地分配和管理域名&#xff0c;确保每个用户或客户都能及时获得所需的域名资源。…

OJ刷题日记:1、双指针(2)

目录 1、11.盛最多的水 2、LCR 179.查找总价格为目标值的两个商品 3、15.三数之和 4、18.四数之和 1、11.盛最多的水 题目&#xff1a; 11. 盛最多水的容器 - 力扣&#xff08;LeetCode&#xff09;https://leetcode.cn/problems/container-with-most-water/description/ …

45---M.2 SSD电路设计

视频链接 M.2 SSD硬件电路设计01_哔哩哔哩_bilibili M.2 SSD电路设计 1、M.2简介 1.1、M.2基本介绍 M.2接口也叫NGFF&#xff0c;英文全称Next Generation Form Factor。M.2接口是为超极本&#xff08;Ultrabook&#xff09;量身定做的新一代接口标准&#xff0c;是Intel推…

【微服务-Nacos】手把手教你Nacos集群部署,不会的来找我!

前面我们介绍了Nacos单机部署和微服务接入Nacos注册中心的操作步骤&#xff0c;但单机部署是分布式应用的大忌&#xff0c;在分布式架构中&#xff0c;任何单点都可能成为系统的瓶颈。因此关于Nacos部署&#xff0c;通常都是采用集群部署来为系统带来高可用性。这里我们来介绍下…