http://blog.csdn.net/imcdragon/article/details/6838565解答二

http://hi.baidu.com/icyday315/item/040aadab454c8a97151073da合并思路(不能重复abcdabcd  就不行了,abcda是最长重复子串)

  1. /*
  2. Author: Mcdragon
  3. Date: 15-07-11 21:17
  4. Description: 求一个字符串中连续出现次数最多的子串.
  5. 基本算法描述:
  6. 给出一个字符串abababa
  7. 1.穷举出所有的后缀子串
  8. substrs[0] = abababa;
  9. substrs[1] = bababa;
  10. substrs[2] = ababa;
  11. substrs[3] = baba;
  12. substrs[4] = aba;
  13. substrs[5] = ba;
  14. substrs[6] = a;
  15. 2.然后进行比较
  16. substrs[0]比substrs[1]多了一个字母,如果说存在连续匹配的字符,那么
  17. substrs[0]的第1个字母要跟substrs[1]首字母匹配,同理
  18. substrs[0]的前2个字母要跟substrs[2]的前2个字母匹配(否则不能叫连续匹配)
  19. substrs[0]的前n个字母要跟substrs[n]的前n个字母匹配.
  20. 如果匹配的并记下匹配次数.如此可以求得最长连续匹配子串.
  21. */

这个题目不是编程珠玑上看到的,但是解法用到的数据结构在编程珠玑上有讲到,先归类到这里。

求一个字符串中连续出现的次数最多的子串。例如字符串“abababc”,最多连续出现的为ab,连续出现三次。要和求一个字符串中的最长重复子串区分开来,还是上面的字符串,那么最长的重复子串为abab。两个题目的解法有些类似,都用到了后缀数组这个数据结构。求一个字符串中连续出现的次数最多的子串,首先生成后缀数组例如上面的字符串为:
abababc
bababc
ababc
babc
abc
bc
c
可以看出第一个后缀数组和第三个后缀数组的起始都为ab,第5个后缀数组也为ab。可以看出规律来,一个字符串s,如果第一次出现在后缀数组i的前面,那么如果它重复出现,下一次出现应该在第i+len(s)个后缀数组的前面。这个规律也不难看出。那么从头到尾按照这个规律搜索下不难得出结果。下面是代码:


[cpp]
 view plaincopy
  1. #include <iostream>
  2. using namespace std;
  3. int con_sub(char *str, char **ret);
  4. int main()
  5. {
  6. char str[] = "abcabcabcabcabcabbbb";
  7. char *ret = NULL;
  8. int time = con_sub(str, &ret);
  9. printf("%s occuers %d times\n", ret, time);
  10. return 0;
  11. }
  12. int con_sub(char *str, char **ret)
  13. {
  14. int max_time = 0;//连续出现的最多次数
  15. int ret_len = 0;//连续出现的字符串的长度
  16. char *addr = NULL;//连续出现字符串的起始地址
  17. int len = strlen(str);
  18. char **a = (char **)malloc(sizeof(char *)*len);
  19. //生成后缀数组
  20. for(int i=0; i<len; i++)
  21. a[i] = &str[i];
  22. //重复字符串的长度范围为1到(len+1)/2
  23. for(int i=1; i<=(len+1)/2; i++)
  24. {
  25. //当重复的字符串长度为i的时候,如果是连续出现的,那么第j和第j+i个后缀数组前面为重复的字符串
  26. for(int j=0; j+i<=len-1; j+=i)
  27. {
  28. int k = j;
  29. int temp_time = 1;
  30. while(k+i <= len-1 && strncmp(a[k], a[k+i], i) == 0)
  31. {
  32. temp_time++;
  33. k += i;
  34. }
  35. if(temp_time > max_time)
  36. {
  37. max_time = temp_time;
  38. ret_len = i;
  39. addr = a[k];
  40. }
  41. }
  42. }
  43. *ret = new char[len+1];
  44. strncpy(*ret, addr, ret_len);
  45. return max_time;
  46. }

求一个字符串中连续出现次数最多的子串相关推荐

  1. 求一个字符串中连续出现的次数最多的子串

    求一个字符串中连续出现的次数最多的子串.例如字符串"abababc",最多连续出现的为ab,连续出现三次.要和求一个字符串中的最长重复子串区分开来,还是上面的字符串,那么最长的重复 ...

  2. Java实现统计某字符串在另一个字符串中出现的次数

    面试时会经常考这样的题目,估计也不让使用正则表达式.还好这个算法还算简单,不过在草稿纸上写难免会出现运行异常,好吧,面试官赢了,乃们屌丝就实实在在的把代码码出来吧. 谢谢"心扉"对 ...

  3. 编写程序,统计一个长度为2的字符串在另一个字符串中出现的次数

    <程序设计基础-c语言>杨莉 刘鸿翔 ISBN-978-7-03-032903-5 p137 习题5 4.统计一个长度为2的字符串在另一个字符串中出现的次数.例如,假定输入的字符串为:as ...

  4. String案例 获取一个字符串在另一个字符串中出现的次数(两种方法)

    /*思路:定义1个计数器和1个截取后的Str-->判断有无SS-->有就截取并计数-->直到截取完没有ss就停止*/ package Day12;/* 练习2 获取一个字符串在另一个 ...

  5. C语言试题四十八之该函数可以统计一个长度为2的字符串在另一个字符串中出现的次数。

    1. 题目 请编写一个函数function,它的功能是:该函数可以统计一个长度为2的字符串在另一个字符串中出现的次数. 2 .温馨提示 C语言试题汇总里可用于计算机二级C语言笔试.机试.研究生复试中C ...

  6. 【字符串问题】求一个字符串中重复出现的最长的子串

    2013-09-14 15:34:16 用后缀数组求一个字符串中重复出现的最长的子串. 用C++中的string类可以很方便地进行操作,需将后缀数组保存在vector<string>,如下 ...

  7. 统计一个字符在另一个字符串中出现的次数

    文章目录 1.一个字符在另一个字符串中出现的次数 2.测试 3.输出 1.一个字符在另一个字符串中出现的次数 /*** showTime 懂得都懂 <br>* @param findStr ...

  8. 统计一个长度为2的子字符串在另一个字符串中出现的次数.例如:假定输入的字符串为“asd asasdfg asd as zx67 asd mklo”,子字符串为“as”,函数返回值为6。

    编写一个函数findStr(),该函数统计一个长度为2的子字符串在另一个字符串中出现的次数.例如:假定输入的字符串为"asd asasdfg asd as zx67 asd mklo&quo ...

  9. 统计一个子字符串在另一个字符串中出现的次数

    统计一个长度为n的字符串在另外一个字符串中出现的次数. 例如:假定输入字符串为helloworldhelloworld,子字符串为he,则应输出2 代码如下: #include <stdio.h ...

最新文章

  1. Emacs中的RSS阅读器--newsticker
  2. Java EE 简介
  3. 智慧校园“手环考勤”已成为学校常态
  4. was not declared in this scope
  5. 为爱追寻_从机械师到编码员:追寻梦想如何改变了我的生活
  6. java gzipoutputstream_java – GZIPInputStream逐行读取
  7. 产品采用的即时通讯软件是本地云架构
  8. Intel VMM-虚拟机监控器
  9. struct对象可能分配在托管堆上吗
  10. Flink Batch SQL 1.10 实践
  11. 为什么我们要设定更高的目标?
  12. java商城源码(servlet,springboot,html,vue,uniapp,小程序,android)一套任意组合
  13. 操作系统进程调度算法(c语言实现)
  14. 定时任务时间表达式规则
  15. Java实现八大排序算法
  16. Android 3D 旋转
  17. KK 的99 条额外的建议[翻译]#yyds干货盘点#
  18. VR中多模式异步协作的挑战和设计考虑因素
  19. Java实现png图片转pdf
  20. mysql 编程算法_十大编程算法助程序员走上高手之路

热门文章

  1. 【正一专栏】最好的回击是打得你好无脾气
  2. (转载)微信公众平台开发入门教程
  3. 详细设计 存储分配_10k+点赞的 Spring Boot 后台管理系统竟然出了详细教程!爱了!...
  4. url传参参数编码的解码问题
  5. CSS3 Flexbox 弹性盒与 css3 阴影效果的演示
  6. Java的知识点19——异常机制Exception
  7. Java 技术篇-借助自定义对象实现函数返回多个不同类型的值实例演示
  8. MySQL 数据库show processlist where条件筛选报错解决方法,[Code: 1064, SQL State: 42000] You have an error in your
  9. PyQt5 技术篇-窗口名、窗口图标的设置方法。
  10. Python 技术篇 - python3使用speech库常见问题原因及解决方法