【优选算法】字符串

一、相关编程题

1.1 最长公共前缀

题目链接

14. 最长公共前缀 - 力扣(LeetCode)

题目描述

在这里插入图片描述

算法原理

在这里插入图片描述

编写代码

// 解法一:两两比较
class Solution {
public:
    string longestCommonPrefix(vector<string>& strs) {
        int k = strs[0].size(); //表示最长公共前缀的结束位置
        for(int i = 0; i < strs.size()-1; ++i)
        {
            for(int j = 0; j < k; ++j)
            {
                if(j==min(strs[i].size(), strs[i+1].size()) || strs[i][j] != strs[i+1][j])
                {
                    k = j;
                    break;
                }
            }
        }
        return string(strs[0], 0, k);
    }
};

// 解法二:统一比较
class Solution {
public:
    string longestCommonPrefix(vector<string>& strs) {
        int k = 0;
        while(k < strs[0].size())
        {
            char ch = strs[0][k];
            for(int i = 1; i < strs.size(); ++i)
            {
                if(k==strs[i].size() || strs[i][k]!=ch)
                    return string(strs[0], 0, k);
            }   
            ++k;
        }
        return strs[0];
    }
};

1.2 最长回文子串

题目链接

5. 最长回文子串 - 力扣(LeetCode)

题目描述

在这里插入图片描述

算法原理

在这里插入图片描述

编写代码

//中心扩展算法
class Solution {
public:
    string longestPalindrome(string s) {
        int maxlen = 0, maxi = 0, n = s.size();
        for(int i = 0; i < n; ++i) //依次枚举所有的中点
        {
            //奇数长度的扩展
            int j = i, k = i;
            for(; j>=0 && k<n; --j, ++k)
             if(s[j] != s[k]) break;
            if(maxlen < k-j-1)
            {
                maxlen = k-j-1;
                maxi = j+1;
            }
            //偶数长度的扩展
            j = i; k = i+1;
            for(; j>=0 && k<n; --j, ++k)
             if(s[j] != s[k]) break;
            if(maxlen < k-j-1)
            {
                maxlen = k-j-1;
                maxi = j+1;
            }
        }

        return s.substr(maxi, maxlen);
    }
};

1.3 二进制求和

题目链接

67. 二进制求和 - 力扣(LeetCode)

题目描述

在这里插入图片描述

算法原理

  • 应该从低位到高位进行加法运算,将每一位的加法结果%2(进制数)就是这一位的结果,/2就是这一位的进位。
  • 要保证将两个运算量的每一位都遍历相加,并不再有进位,此时结束循环。
  • 要将最终的计算结果逆序才能得到正确的答案。

编写代码

class Solution {
public:
    string addBinary(string a, string b) {
        int i = a.size()-1, j = b.size()-1, t = 0;
        string ret;
        while(i>=0 || j>=0 || t>0)
        {
            if(i>=0) t+=a[i--]-'0';
            if(j>=0) t+=b[j--]-'0';
            ret+=t%2+'0';
            t/=2;
        }
        reverse(ret.begin(), ret.end());
        return ret;
    }
};

1.4 字符串相乘

题目链接

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

题目描述

在这里插入图片描述

算法原理

在这里插入图片描述

编写代码

//解法一:模拟
class Solution {
public:
    string multiply(string num1, string num2) {
        //为了从低位到高位相乘,先将两字符串逆序
        reverse(num1.begin(), num1.end());
        reverse(num2.begin(), num2.end());
        string tmp, ret; //tmp存储每位相乘的结果,ret是最终结果

        //用num1的每一位与num2相乘,再将tmp结果相加到ret
        for(int i = 0; i < num1.size(); ++i) 
        {
            tmp.clear();
            for(int k = 0; k < i; ++k) tmp+='0'; //高位相乘补'0'
            int mul = 0; //保存每位相乘的结果及进位
            for(int j = 0; j < num2.size(); ++j)
            {
                mul += (num1[i]-'0')*(num2[j]-'0');
                tmp+=mul%10+'0';
                mul/=10;
            }
            while(mul>0)
            {
                tmp+=mul%10+'0';
                mul/=10;
            }
            ret = StrSum(ret, tmp); 
        }
        //处理前导'0'
        int i = ret.size()-1;
        while(i>0) //注意个位的'0'保留
        {
            if(ret[i] != '0') break;
            else --i;
        }
        ret.resize(i+1);
        //将结果翻转
        reverse(ret.begin(), ret.end());
        return ret;
    }

    //两逆序字符串相加,返回的结果也是逆序的(从低位到高位)
    string StrSum(const string& str1,const string& str2)
    {
        int i = 0, j = 0, t = 0;
        string ret;
        while(i<str1.size() || j<str2.size() || t>0)
        {
            if(i<str1.size()) t+=str1[i++]-'0';
            if(j<str2.size()) t+=str2[j++]-'0';
            ret += t%10+'0';
            t/=10;
        }
        return ret;
    }
};

//解法二:无进位相乘再相加,最后处理进位
class Solution {
public:
    string multiply(string num1, string num2) {
        //为了从低位到高位相乘,先将两字符串逆序
        reverse(num1.begin(), num1.end());
        reverse(num2.begin(), num2.end());
        //无进位相乘然后相加
        int m = num1.size(), n = num2.size();
        vector<int> tmp(m+n-1, 0);
        for(int i = 0; i < m; ++i)
        {
            for(int j = 0; j < n; ++j)
            {
                tmp[i+j] += (num1[i]-'0')*(num2[j]-'0');
            }
        }
        //最后处理进位
        string ret;
        int t = 0, i = 0;
        while(i<tmp.size() || t>0)
        {
            if(i<m+n-1) t+=tmp[i++];
            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/697511.html

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

相关文章

《QT实用小工具·七十》openssl+qt开发的P2P文件加密传输工具

1、概述 源码放在文章末尾 该项目实现了P2P的文件加密传输功能&#xff0c;具体包含如下功能&#xff1a; 1、 多文件多线程传输 2、rsaaes文件传输加密 3、秘钥随机生成 4、断点续传 5、跨域传输引导服务器 项目界面如下所示&#xff1a; 接收界面 发送界面 RSA秘钥生成…

CTF-PWN-kernel-UAF

文章目录 参考slub 分配器kmem_cache_cpukmem_cache_node[ ]冻结和解冻分配释放 fork绑核Kmalloc flag和slub隔离CISCN - 2017 - babydriver检查babtdriver_initstruct cdevalloc_chrdev_regioncdev_initownercdev_add_class_createdevice_create babyopenbabyreleasebabyreadb…

CleanMyMac2024最新免费电脑Mac系统优化工具

大家好&#xff0c;我是你们的好朋友——软件评测专家&#xff0c;同时也是一名技术博主。今天我要给大家种草一个超级实用的Mac优化工具——CleanMyMac&#xff01; 作为一个长期使用macOS的用户&#xff0c;我深知系统运行时间长了&#xff0c;缓存文件、日志、临时文件等都会…

数据库管理-第200期 身边的数据库从业者(20240610)

数据库管理200期 2024-06-10 数据库管理-第200期 身边的数据库从业者&#xff08;20240610&#xff09;首席-薛晓刚院长-施嘉伟邦德-王丁丁强哥-徐小强会长-吴洋灿神-熊灿灿所长-严少安探长-张震总结活动预告 数据库管理-第200期 身边的数据库从业者&#xff08;20240610&#…

**《Linux/Unix系统编程手册》读书笔记24章**

D 24章 进程的创建 425 24.1 fork()、exit()、wait()以及execve()的简介 425 . 系统调用fork()允许父进程创建子进程 . 库函数exit(status)终止进程&#xff0c;将进程占用的所有资源归还内核&#xff0c;交其进行再次分配。库函数exit()位于系统调用_exit()之上。在调用fo…

HTML开发的最主要的三种框架及Python实现

一、介绍 HTML本身是一种标记语言&#xff0c;用于构建网页的结构。然而&#xff0c;当谈到HTML开发框架时&#xff0c;通常指的是那些提供了额外的功能和工具&#xff0c;以帮助开发者更高效地构建网页和应用程序的框架。有三种流行的HTML开发框架&#xff1a; Bootstrap 简介…

基于JSP技术的网络视频播放器

你好呀&#xff0c;我是计算机学长猫哥&#xff01;如果有相关需求&#xff0c;文末可以找到我的联系方式。 开发语言&#xff1a;Java 数据库&#xff1a;MySQL 技术&#xff1a;JSP技术 工具&#xff1a;IDEA/Eclipse、Navicat、Maven 系统展示 首页 管理员界面 用户界…

网络分析(ArcPy)

一.前言 GIS中的网络分析最重要的便是纠正拓扑关系&#xff0c;建立矫正好的网络数据集&#xff0c;再进行网络分析&#xff0c;一般大家都是鼠标在arcgis上点点点&#xff0c;今天说一下Arcpy来解决的方案&#xff0c;对python的要求并不高,具体api参数查询arcgis帮助文档即可…

渗透测试模拟实战(二)-BlueCMS平台

渗透测试 渗透测试是维护网络安全的重要组成部分&#xff0c;可以帮助组织识别并修复潜在的安全漏洞&#xff0c;减少被恶意攻击的风险。然而&#xff0c;进行渗透测试时必须遵守法律和道德规范&#xff0c;确保所有活动都在授权范围内进行。 环境部署&#xff1a; study2016、…

逆序队专题

逆序对的定义是&#xff0c;在一个数组中&#xff0c;对于下标 ( i ) 和 ( j )&#xff08;其中 ( i < j )&#xff09;&#xff0c;如果 ( a[i] > a[j] )&#xff0c;则称 ((a[i], a[j])) 为数组的一个逆序对。 换句话说&#xff0c;逆序对就是在数组中前面的元素大于后…

分布式事务AP控制方案(上)

分布式事务控制方案 本篇文章给出一种要求高可用性&#xff08;AP思想&#xff09;的分布式事务控制方案 下篇新鲜出炉&#xff1a;点我查看 分布式事务控制方案1、业务背景2、本地消息表的设计3、对消息表的操作4、任务调度5、任务流程控制的抽象类6、课程发布的实现类7、总…

【C++】C++ QT实现Huffman编码器与解码器(源码+课程论文+文件)【独一无二】

&#x1f449;博__主&#x1f448;&#xff1a;米码收割机 &#x1f449;技__能&#x1f448;&#xff1a;C/Python语言 &#x1f449;公众号&#x1f448;&#xff1a;测试开发自动化【获取源码商业合作】 &#x1f449;荣__誉&#x1f448;&#xff1a;阿里云博客专家博主、5…

Vue17-条件渲染

一、使用v-show属性做条件渲染 控制元素的显示和隐藏 v-show里面也能是表达式&#xff0c;只要表达式的值是boolean就行。 或者 当时结构还在&#xff1a; 二、使用v-if属性做条件渲染 结构也不在了 三、示例 方式一&#xff1a; 方式二&#xff1a; 当元素有很高的切换频率&am…

机器学习实验----支持向量机(SVM)实现二分类

目录 一、介绍 (1)解释算法 (2)数据集解释 二、算法实现和代码介绍 1.超平面 2.分类判别模型 3.点到超平面的距离 4.margin 间隔 5.拉格朗日乘数法KKT不等式 (1)介绍 (2)对偶问题 (3)惩罚参数 (4)求解 6.核函数解决非线性问题 7.SMO (1)更新w (2)更新b 三、代…

我在得物的这两年

写在前面 这篇文章非常简单&#xff0c;和大家简单聊聊我在得物的这两年&#xff0c;也是从学生到社会人的这两年。 我是2022年的6月加入得物实习&#xff0c;负责某个业务中台的后端研发&#xff0c;那一年我21岁&#xff0c;还在读大三&#xff0c;还在迷茫未来是读研还是工…

nw.js 如何调用activeX控件 (控件是C++编写的dll文件)

&#x1f3c6;本文收录于「Bug调优」专栏&#xff0c;主要记录项目实战过程中的Bug之前因后果及提供真实有效的解决方案&#xff0c;希望能够助你一臂之力&#xff0c;帮你早日登顶实现财富自由&#x1f680;&#xff1b;同时&#xff0c;欢迎大家关注&&收藏&&…

【氵】Archlinux+KDE Plasma 6+Wayland 安装nvidia驱动 / 开启HDR

参考: NVIDIA - Arch Linux 中文维基 &#xff08;其实就是把 wiki 简化了一下 注&#xff1a;本教程适用 GeForce 930 起、10 系至 20 系、 Quadro / Tesla / Tegra K-系列以及更新的显卡&#xff08;NV110 以及更新的显卡家族&#xff09;&#xff0c;此处以 RTX3060 为例 …

Cyber Weekly #10

赛博新闻 1、最强开源大模型面世&#xff1a;阿里发布Qwen2 6月7日凌晨&#xff0c;阿里巴巴通义千问团队发布了Qwen2系列开源模型。该系列模型包括5个尺寸的预训练和指令微调模型&#xff1a;Qwen2-0.5B、Qwen2-1.5B、Qwen2-7B、Qwen2-57B-A14B以及Qwen2-72B。据Qwen官方博客…

1.奖牌的数量

上海市计算机学会竞赛平台 | YACSYACS 是由上海市计算机学会于2019年发起的活动,旨在激发青少年对学习人工智能与算法设计的热情与兴趣,提升青少年科学素养,引导青少年投身创新发现和科研实践活动。https://www.iai.sh.cn/problem/447 题目描述 小爱获得了 𝑎a 枚金牌,…

MATLAB实现磷虾算法(Krill herd algorithm)

1.算法介绍 磷虾算法&#xff08;Krill Herd Algorithm, KH&#xff09;是一种基于生物启发的优化算法&#xff0c;其原理模拟了南极磷虾&#xff08;Euphausia superba&#xff09;群体的聚集行为。该算法旨在通过模拟磷虾个体间的相互作用、觅食行为和随机扩散&#xff0c;来…