news 2026/7/5 14:03:28

经典算法题详解之统计重复个数(二)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
经典算法题详解之统计重复个数(二)

​解决方案

思路

由于题目中的 n1 和 n2 都很大,因此我们无法真正把 S1 = [s1, n1] 和 S2 = [s2, n2] 都显式地表示出来。由于这两个字符串都是不断循环的,因此我们可以考虑找出 s2 在 S1 中出现的循环节,如果我们找到了循环节,那么我们就可以很快算出 s2 在 S1 中出现了多少次了。

有些读者可能对循环节这个概念会有些陌生,这个概念我们可以类比无限循环小数,如果从小数部分的某一位起向右进行到某一位止的一节数字「循环」出现,首尾衔接,称这种小数为「无限循环小数」,这一节数字称为「无限循环小数」。比如对于 3.56789789789... 这个无限循环小数,它的小数部分就是以 789 为一个「循环节」在无限循环,且开头可能会有部分不循环的部分,这个数字中即为 56。

那么回到这题,我们可以将不断循环的 s2 组成的字符串类比作上面小数部分,去找是否存在一个子串,即「循环节」,满足不断在 S2 中循环,且这个循环节能对应固定数量的 s1 。如下图所示,在第一次出现后,S2 的子串 bdadc 构成一个循环节:之后 bdadc 的每次出现都需要有相应的两段 s1。

当我们找出循环节后,我们即可知道一个循环节内包含 s1 的数量,以及在循环节出现前的 s1 的数量,这样就可以在 O(1) 的时间内,通过简单的运算求出 s2 在 S1 中出现的次数了。当然,由于 S1 中 s1 的数量 n1 是有限的,因此可能会存在循环节最后一个部分没有完全匹配,如上图最后会单独剩一个 s1 出来无法完全匹配完循环节,这部分我们需要单独拿出来遍历处理统计。

有些读者可能会怀疑循环节是否一定存在,这里我们给出的答案是肯定的,根据鸽笼原理,我们最多只要找过 |s2| + 1 个 s1,就一定会出现循环节。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/7/4 12:15:37

SSDTTime黑苹果配置指南:告别繁琐的手动补丁制作

SSDTTime黑苹果配置指南:告别繁琐的手动补丁制作 【免费下载链接】SSDTTime SSDT/DSDT hotpatch attempts. 项目地址: https://gitcode.com/gh_mirrors/ss/SSDTTime 还在为复杂的黑苹果配置而烦恼吗?每次面对DSDT补丁都感觉无从下手?S…

作者头像 李华
网站建设 2026/7/4 15:22:58

5步解决AFFiNE开发环境配置难题:从零到部署的完整指南

5步解决AFFiNE开发环境配置难题:从零到部署的完整指南 【免费下载链接】AFFiNE AFFiNE 是一个开源、一体化的工作区和操作系统,适用于组装您的知识库等的所有构建块 - 维基、知识管理、演示和数字资产。它是 Notion 和 Miro 的更好替代品。 项目地址: …

作者头像 李华
网站建设 2026/7/4 21:06:10

成本降67%性能反超!Qwen3-30B-A3B双模式架构重塑企业AI应用

成本降67%性能反超!Qwen3-30B-A3B双模式架构重塑企业AI应用 【免费下载链接】Qwen3-30B-A3B-GGUF 项目地址: https://ai.gitcode.com/hf_mirrors/Qwen/Qwen3-30B-A3B-GGUF 导语 阿里达摩院开源的Qwen3-30B-A3B模型以305亿总参数实现复杂推理与高效响应的无…

作者头像 李华
网站建设 2026/7/4 19:58:39

VDA 6.3标准:汽车行业质量审核的核心指南

作为汽车行业质量管理的基石,VDA 6.3标准在供应链审核中发挥着至关重要的作用。今天,我们将深入探讨这一重要标准,帮助您更好地理解和应用它。 【免费下载链接】VDA6.32016中文版资源下载 本仓库提供VDA 6.3 2016中文版PDF文件下载&#xff0…

作者头像 李华
网站建设 2026/7/3 7:07:23

Spark命令行工具终极指南:快速生成简洁数据趋势图表

Spark命令行工具终极指南:快速生成简洁数据趋势图表 【免费下载链接】spark ▁▂▃▅▂▇ in your shell. 项目地址: https://gitcode.com/gh_mirrors/spark/spark Spark是一个轻量级的命令行工具,专门用于生成简洁的数据趋势图表。这种被称为Sp…

作者头像 李华