[Leedcode][JAVA][第466题][统计重复个数][数组]

【问题描述】466. 统计重复个数

由 n 个连接的字符串 s 组成字符串 S,记作 S = [s,n]。例如,["abc",3]=“abcabcabc”。如果我们可以从 s2 中删除某些字符使其变为 s1,则称字符串 s1 可以从字符串 s2 获得。例如,根据定义,"abc" 可以从 “abdbec” 获得,但不能从 “acbbe” 获得。现在给你两个非空字符串 s1 和 s2(每个最多 100 个字符长)和两个整数 0 ≤ n1 ≤ 106 和 1 ≤ n2 ≤ 106。现在考虑字符串 S1 和 S2,其中 S1=[s1,n1] 、S2=[s2,n2] 。请你找出一个可以满足使[S2,M] 从 S1 获得的最大整数 M 。示例:
输入:
s1 ="acb",n1 = 4
s2 ="ab",n2 = 2返回:
2

【解答思路】

1. 暴力解法
  • 在s1的拼接字符串中 遍历找到找到一个 s2,记录使用了s1的个数
  • s1总个数/含单个s2循环体/s2总个数
    时间复杂度:O(N^2) 空间复杂度:O(1)
public int getMaxRepetitions(String s1, int n1, String s2, int n2) {char[] c1 = s1.toCharArray();char[] c2 = s2.toCharArray();/*** index为c2的索引, num1当前使用了ss1的个数, num2当前匹配的ss2的个数*/int index = 0 , num1 = 0, num2 = 0;while(num1 < n1){for(int i = 0 ; i < c1.length ; i++){if(c1[i] == c2[index]){if(index == c2.length - 1) {index = 0;num2 ++;}else{index ++;}      }}num1++;}return num2 / n2;}
2. 优化

1.分为 0 ~(n1-1)次拼接s1,记录下第0次 时,count(即s2出现的次数) 和 index(即指向s2的坐标)
2.循环找寻坏体,判断为循坏体的条件是:i!=0(不是第0次) && indexpre_index (当前指向s2的坐标第0次拼接结束后指向s2的坐标)
3.如果找到了循环体,那么return (循环体个数 * (单个循环体包含的s2数目) + 除去所有循环体字符串后,剩余拼接在一起的形成的字符串可以找出s2个数)/ n2,可以配合代码看
4.没有找到循环体,那就直接返回迄今为止记录到的count数/n2,即countRecorder[n-1]/n2
时间复杂度:O(N) 空间复杂度:O(1)

public int getMaxRepetitions(String s1, int n1, String s2, int n2) {int len1 = s1.length();int len2 = s2.length();// 有0的话不多说,直接滚0if (len1 == 0 || len2 == 0 || n1 == 0 || n2 == 0) {return 0;}char[] chars1 = s1.toCharArray();char[] chars2 = s2.toCharArray();int index = 0;//记录s2的坐标int count = 0;//记录s1包含s2的个数int[] countRecorder = new int[n1 + 1];//记录第i次拼接时候累积的countint pre_index=0;//记录第0次结束后的index//开始拼接找循环体( 看作 0~n-1 次)for (int i = 0; i < n1; ++i) {// 第i次拼接s1,更新index和countfor (int j = 0; j < len1; ++j) {if (chars1[j] == chars2[index]) {//匹配成功,index++index++;}if (index == chars2.length) {//完成一个s2的匹配,count++index = 0;count++;}}countRecorder[i] = count;//记录第0次到第i次拼接出现的s2匹配次数(count)if(i==0) {//记录第0次的下标indexpre_index = index;}//符合该条件,代表找到循环体了,可以缩短搜索时间if(i!=0 && pre_index == index) {//System.out.println(countRecorder[0]);int pre = countRecorder[0];//第一次拼接的时候记录的countint loop_part = ((n1-1) / i) * (countRecorder[i]-pre);//除去循环体部分,其他部分合并在一起// x = (n1-1)%i --> 除去循环体还等于x个s2拼接 int other_part = countRecorder[(n1-1) % i];//返回值为出现的s2的总次数return (loop_part+other_part) / n2;}}//未找到循环,只能暴力了,裂开return countRecorder[n1-1] / n2;}

【总结】

1. 数组拼接题目 重复延长思想 找规律
2. 完全不知道如何入手 过于菜 不断总结整理归纳

image.png
参考链接:https://leetcode-cn.com/problems/count-the-repetitions/solution/tong-ji-zhong-fu-ge-shu-_jian-dan-yi-dong-by-xiang/

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

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

相关文章

phantomJs原理

引用文段&#xff1a;链接&#xff1a;https://www.jianshu.com/p/0254391918f7 网页渲染可分为服务端渲染和客户端渲染&#xff0c;前者是指你在浏览器地址栏输入一个网址&#xff0c;Web服务器处理请求过程就将所有需要呈现的html元素都构造好了&#xff0c;浏览器收到响应就…

oracle t44,SecureFiles LOBs基础知识之存储篇

SecureFiles LOBs相比于BasicFilesLOBs具有加密(encryption)、去重(deduplicaiton)、压缩(compression)等新功能&#xff0c;pctversion&#xff0c;chunksize等参数也仅仅为了向后兼容而保留&#xff0c;因此SecureFiles LOBs的自适应能力更强&#xff0c;在管理上更为简化&am…

[Leedcode][JAVA][第200题][岛屿数量][DFS][BFS][并查集]

【问题描述】 第200题 岛屿数量 给你一个由 1&#xff08;陆地&#xff09;和 0&#xff08;水&#xff09;组成的的二维网格&#xff0c;请你计算网格中岛屿的数量。岛屿总是被水包围&#xff0c;并且每座岛屿只能由水平方向和/或竖直方向上相邻的陆地连接形成。此外&#xf…

python闯关_Day012

day012 用python实现信息卡管理及购物商城的项目 需求 #需求: 1 这是一个信用卡管理程序 2 用户手持信用卡购物&#xff0c;使用函数&#xff0c;按照软件开发规范 3 用户名密码存放于文件中&#xff0c;支持多用户登陆&#xff0c;使用json 4 程序启动&#xff0c;先登录或者…

[Leedcode][JAVA][第1248题][统计「优美子数组][找规律]

【问题描述】 1248. 统计「优美子数组」 给你一个整数数组 nums 和一个整数 k。如果某个 连续 子数组中恰好有 k 个奇数数字&#xff0c;我们就认为这个子数组是「优美子数组」。请返回这个数组中「优美子数组」的数目。 示例 1&#xff1a;输入&#xff1a;nums [1,1,2,1,1]…

[ubuntu setting]Change system language

1.Open the software "语言支持". ​ 2.Then select "English" lauguage, an apply to whole system. ​ 3.reboot system. [end]转载于:https://www.cnblogs.com/lizhuohui/p/10274356.html

http:(4):http请求方法

HTTP 消息结构 HTTP是基于客户端/服务端&#xff08;C/S&#xff09;的架构模型&#xff0c;通过一个可靠的链接来交换信息&#xff0c;是一个无状态的请求/响应协议。 一个HTTP"客户端"是一个应用程序&#xff08;Web浏览器或其他任何客户端&#xff09;&#xff…

[Leedcode][JAVA][第199题][二叉树的右视图][BFS][DFS][前中后序遍历]

【问题描述】199.二叉树的右视图 给定一棵二叉树&#xff0c;想象自己站在它的右侧&#xff0c;按照从顶部到底部的顺序&#xff0c;返回从右侧所能看到的节点值。示例:输入: [1,2,3,null,5,null,4] 输出: [1, 3, 4] 解释:1 <---/ \ 2 3 <---\…

基于声音的击键信号识别

摘要 本文文章采用击键信号的短时能量及峰值片段的幅度及各个幅度对应的频率作为特征向量。采用声音搜集装置搜集敲击键盘产生的声音信号&#xff0c;并对声音信号进行巴特沃斯滤波方法进行滤波预处理&#xff1b;将上述经过滤波得到的信号减去环境背景信号&#xff0c;得到当…

http:(5):http状态码

HTTP状态码 当浏览者访问一个网页时&#xff0c;浏览者的浏览器会向网页所在服务器发出请求。当浏览器接收并显示网页前&#xff0c;此网页所在的服务器会返回一个包含HTTP状态码的信息头&#xff08;server header&#xff09;用以响应浏览器的请求。 HTTP状态码的英文为HTT…

[爬虫][python][入门][网页源码][百度图片][豆瓣TOP250]

Robots协议 查看爬取规则 遵守相关法律法规 Robots协议&#xff08;也称为爬虫协议、机器人协议等&#xff09;的全称是“网络爬虫排除标准”&#xff08;Robots Exclusion Protocol&#xff09;&#xff0c;网站通过Robots协议告诉爬虫哪些页面可以抓取&#xff0c;哪些页面不…

mysql(1):查找语句练习

1创建一个员工表 CREATE TABLE employees ( emp_no int(11) NOT NULL, birth_date date NOT NULL, first_name varchar(14) NOT NULL, last_name varchar(16) NOT NULL, gender char(1) NOT NULL, hire_date date NOT NULL, PRIMARY KEY (emp_no)); 2插入数据 insert into em…

[Leedcode][JAVA][面试题 08.11][硬币][动态规划]

【问题描述】 面试题 08.11.硬币 硬币。给定数量不限的硬币&#xff0c;币值为25分、10分、5分和1分&#xff0c;编写代码计算n分有几种表示法。(结果可能会很大&#xff0c;你需要将结果模上1000000007)示例1:输入: n 5输出&#xff1a;2解释: 有两种方式可以凑成总金额: 55…

Java课程设计

目录 Magic-Towers一、团队课程设计博客链接团队博客地址二、个人负责模块或任务说明三、自己的代码提交记录截图四、课程设计感想Magic-Towers 一、团队课程设计博客链接 团队博客地址 二、个人负责模块或任务说明 任务分配  网络1713柳聪灵【组长】--Model游戏布局及障碍物的…

玩转oracle 11g(44):数据库发展历史

数据库发展历史 数据库技术从 20 世纪 60 年代开始到现在一共经历了三个发展阶段&#xff1a;  第一代是网状、层次数据库系统 网状 &#xff1a;通用电气公司 Bachman 等人在 1961 年开发成功的 IDS 层次 &#xff1a; IBM 公司在 1968 年开发的 IMS 第二代是关…

[Java学习资料] [成长之路]

[背景] 网上学习资料千千万万&#xff0c;成长之路千千万万&#xff0c;各取所需 JAVA基础 网站 https://www.runoob.com/java/java-tutorial.html https://www.w3cschool.cn/java/dict 公众号 书籍 算法 网站 labuladong https://github.com/labuladong/fucking-algo…

word 2013 题注、图注、插入图片自动修改大小、批量更新题注编号

1 、题注 图片下面的文字说明&#xff0c;如 图 1.1.1 2、图注 图的标题格式&#xff0c;可以右键修改段落为居中&#xff0c;选中图片&#xff0c;点下此格式快捷居中等其他格式 3、 题注插入 效果 如下 4、题注自动居中对齐 先点击图片--》居中&#xff0c;或者点图注居中…

玩转oracle 11g(45):关系数据库

关系数据库 关系模型 定义&#xff1a;以二维表的形式表示实体和实体之间联系的数据模型称为关系数据模型。 从模型的三要素角度看&#xff0c;关系模型的内容为&#xff1a; &#xff08; 1 &#xff09;数据结构&#xff1a;一张二维表格。 &#xf…

[剑指offer][JAVA]面试题[51][数组中的逆序对][归并排序]

【问题描述】面试题51.数组中的逆序对 &#xff08;困难&#xff09; 在数组中的两个数字&#xff0c;如果前面一个数字大于后面的数字&#xff0c;则这两个数字组成一个逆序对。输入一个数组&#xff0c;求出这个数组中的逆序对的总数。 示例 1:输入: [7,5,6,4] 输出: 5限制&…

2019年1月16日【第三天学习】

2019年1月16日星期三 任务一、运行CrackMe1.exe&#xff0c;提示 "嗯&#xff0c;对了" 代表成功。首先修改exe使得出现成功提示&#xff0c;其次不修改exe输入正确的密码达到成功的目的。 hint:https://blog.csdn.net/Nagi_Way/article/details/68961121 使用.Net的…