求一个字符串中连续出现次数最多的子串
http://blog.csdn.net/imcdragon/article/details/6838565解答二
http://hi.baidu.com/icyday315/item/040aadab454c8a97151073da合并思路(不能重复abcdabcd 就不行了,abcda是最长重复子串)
- /*
- Author: Mcdragon
- Date: 15-07-11 21:17
- Description: 求一个字符串中连续出现次数最多的子串.
- 基本算法描述:
- 给出一个字符串abababa
- 1.穷举出所有的后缀子串
- substrs[0] = abababa;
- substrs[1] = bababa;
- substrs[2] = ababa;
- substrs[3] = baba;
- substrs[4] = aba;
- substrs[5] = ba;
- substrs[6] = a;
- 2.然后进行比较
- substrs[0]比substrs[1]多了一个字母,如果说存在连续匹配的字符,那么
- substrs[0]的第1个字母要跟substrs[1]首字母匹配,同理
- substrs[0]的前2个字母要跟substrs[2]的前2个字母匹配(否则不能叫连续匹配)
- substrs[0]的前n个字母要跟substrs[n]的前n个字母匹配.
- 如果匹配的并记下匹配次数.如此可以求得最长连续匹配子串.
- */
这个题目不是编程珠玑上看到的,但是解法用到的数据结构在编程珠玑上有讲到,先归类到这里。
求一个字符串中连续出现的次数最多的子串。例如字符串“abababc”,最多连续出现的为ab,连续出现三次。要和求一个字符串中的最长重复子串区分开来,还是上面的字符串,那么最长的重复子串为abab。两个题目的解法有些类似,都用到了后缀数组这个数据结构。求一个字符串中连续出现的次数最多的子串,首先生成后缀数组例如上面的字符串为:
abababc
bababc
ababc
babc
abc
bc
c
可以看出第一个后缀数组和第三个后缀数组的起始都为ab,第5个后缀数组也为ab。可以看出规律来,一个字符串s,如果第一次出现在后缀数组i的前面,那么如果它重复出现,下一次出现应该在第i+len(s)个后缀数组的前面。这个规律也不难看出。那么从头到尾按照这个规律搜索下不难得出结果。下面是代码:
[cpp] view plaincopy
- #include <iostream>
- using namespace std;
- int con_sub(char *str, char **ret);
- int main()
- {
- char str[] = "abcabcabcabcabcabbbb";
- char *ret = NULL;
- int time = con_sub(str, &ret);
- printf("%s occuers %d times\n", ret, time);
- return 0;
- }
- int con_sub(char *str, char **ret)
- {
- int max_time = 0;//连续出现的最多次数
- int ret_len = 0;//连续出现的字符串的长度
- char *addr = NULL;//连续出现字符串的起始地址
- int len = strlen(str);
- char **a = (char **)malloc(sizeof(char *)*len);
- //生成后缀数组
- for(int i=0; i<len; i++)
- a[i] = &str[i];
- //重复字符串的长度范围为1到(len+1)/2
- for(int i=1; i<=(len+1)/2; i++)
- {
- //当重复的字符串长度为i的时候,如果是连续出现的,那么第j和第j+i个后缀数组前面为重复的字符串
- for(int j=0; j+i<=len-1; j+=i)
- {
- int k = j;
- int temp_time = 1;
- while(k+i <= len-1 && strncmp(a[k], a[k+i], i) == 0)
- {
- temp_time++;
- k += i;
- }
- if(temp_time > max_time)
- {
- max_time = temp_time;
- ret_len = i;
- addr = a[k];
- }
- }
- }
- *ret = new char[len+1];
- strncpy(*ret, addr, ret_len);
- return max_time;
- }
求一个字符串中连续出现次数最多的子串相关推荐
- 求一个字符串中连续出现的次数最多的子串
求一个字符串中连续出现的次数最多的子串.例如字符串"abababc",最多连续出现的为ab,连续出现三次.要和求一个字符串中的最长重复子串区分开来,还是上面的字符串,那么最长的重复 ...
- Java实现统计某字符串在另一个字符串中出现的次数
面试时会经常考这样的题目,估计也不让使用正则表达式.还好这个算法还算简单,不过在草稿纸上写难免会出现运行异常,好吧,面试官赢了,乃们屌丝就实实在在的把代码码出来吧. 谢谢"心扉"对 ...
- 编写程序,统计一个长度为2的字符串在另一个字符串中出现的次数
<程序设计基础-c语言>杨莉 刘鸿翔 ISBN-978-7-03-032903-5 p137 习题5 4.统计一个长度为2的字符串在另一个字符串中出现的次数.例如,假定输入的字符串为:as ...
- String案例 获取一个字符串在另一个字符串中出现的次数(两种方法)
/*思路:定义1个计数器和1个截取后的Str-->判断有无SS-->有就截取并计数-->直到截取完没有ss就停止*/ package Day12;/* 练习2 获取一个字符串在另一个 ...
- C语言试题四十八之该函数可以统计一个长度为2的字符串在另一个字符串中出现的次数。
1. 题目 请编写一个函数function,它的功能是:该函数可以统计一个长度为2的字符串在另一个字符串中出现的次数. 2 .温馨提示 C语言试题汇总里可用于计算机二级C语言笔试.机试.研究生复试中C ...
- 【字符串问题】求一个字符串中重复出现的最长的子串
2013-09-14 15:34:16 用后缀数组求一个字符串中重复出现的最长的子串. 用C++中的string类可以很方便地进行操作,需将后缀数组保存在vector<string>,如下 ...
- 统计一个字符在另一个字符串中出现的次数
文章目录 1.一个字符在另一个字符串中出现的次数 2.测试 3.输出 1.一个字符在另一个字符串中出现的次数 /*** showTime 懂得都懂 <br>* @param findStr ...
- 统计一个长度为2的子字符串在另一个字符串中出现的次数.例如:假定输入的字符串为“asd asasdfg asd as zx67 asd mklo”,子字符串为“as”,函数返回值为6。
编写一个函数findStr(),该函数统计一个长度为2的子字符串在另一个字符串中出现的次数.例如:假定输入的字符串为"asd asasdfg asd as zx67 asd mklo&quo ...
- 统计一个子字符串在另一个字符串中出现的次数
统计一个长度为n的字符串在另外一个字符串中出现的次数. 例如:假定输入字符串为helloworldhelloworld,子字符串为he,则应输出2 代码如下: #include <stdio.h ...
最新文章
- Emacs中的RSS阅读器--newsticker
- Java EE 简介
- 智慧校园“手环考勤”已成为学校常态
- was not declared in this scope
- 为爱追寻_从机械师到编码员:追寻梦想如何改变了我的生活
- java gzipoutputstream_java – GZIPInputStream逐行读取
- 产品采用的即时通讯软件是本地云架构
- Intel VMM-虚拟机监控器
- struct对象可能分配在托管堆上吗
- Flink Batch SQL 1.10 实践
- 为什么我们要设定更高的目标?
- java商城源码(servlet,springboot,html,vue,uniapp,小程序,android)一套任意组合
- 操作系统进程调度算法(c语言实现)
- 定时任务时间表达式规则
- Java实现八大排序算法
- Android 3D 旋转
- KK 的99 条额外的建议[翻译]#yyds干货盘点#
- VR中多模式异步协作的挑战和设计考虑因素
- Java实现png图片转pdf
- mysql 编程算法_十大编程算法助程序员走上高手之路
热门文章
- 【正一专栏】最好的回击是打得你好无脾气
- (转载)微信公众平台开发入门教程
- 详细设计 存储分配_10k+点赞的 Spring Boot 后台管理系统竟然出了详细教程!爱了!...
- url传参参数编码的解码问题
- CSS3 Flexbox 弹性盒与 css3 阴影效果的演示
- Java的知识点19——异常机制Exception
- Java 技术篇-借助自定义对象实现函数返回多个不同类型的值实例演示
- MySQL 数据库show processlist where条件筛选报错解决方法,[Code: 1064, SQL State: 42000] You have an error in your
- PyQt5 技术篇-窗口名、窗口图标的设置方法。
- Python 技术篇 - python3使用speech库常见问题原因及解决方法