标签:算法
问题描述:
找出字符串中所以最长连续重复子串及其个数
比如:
输入:123234,最大连续重复字符串为23,个数为2
输入:5555,最大连续重复字符串为555,个数为2
输入:aaabbb 最大连续重复字符串为aa,个数为2;和bb,个数为2
必须存在重复的字符串才算,只出现一次的不算。可能存在多个相同长度的不同字符串,比如aaabbb。
与[求一个字符串中连续出现次数最多的子串]的区别体现在两个方面:一是要找最长子串(重复次数大于等于2即可);二是要考虑子串是有重叠的重复,如eeee的最长子串为eee。在上一题中, 有重叠的肯定不是连续出现次数最多的。
#include <iostream>
#include <cstring>
#include <utility>
#include <string>
#include <vector>
using namespace std;
vector<pair<int, string>> fun(const string& str)
{
vector<string> subs;
vector<pair<int, string>> res;
int len = str.size();
for (int i = 0; i < len; i++)
{
subs.push_back(str.substr(i));
}
int count = 1;
int maxCount = 1;
int subLen = 1;
string sub;
//i为子串的长度
for (int i = 1; i < len; i++)
{
for (int j = 0; j < len - 1; j++)
{
count = 1;
for (int k = j + 1; k <= j + i && subs[k].size() >= i; k++)
{
if (subs[k].substr(0, i) == subs[j].substr(0, i))
{
count++;
break;
}
}
if (count >= 2)
{
if (i > subLen)
{
res.clear();
}
subLen = i;
maxCount = count;
sub = subs[j].substr(0, i);
res.push_back(make_pair(maxCount, sub));
}
}
}
return res;
}
int main()
{
string str;
vector<pair<int, string>> res;
while (cin>>str)
{
res = fun(str);
for (auto it = res.begin(); it != res.end(); it++)
{
cout<<it->second<<":"<<it->first<<endl;
}
}
return 0;
}
版权声明:本文为博主原创文章,未经博主允许不得转载。
标签:算法
原文地址:http://blog.csdn.net/foreverling/article/details/46888863