最新的微软面试题,题目:求一个字符串中连续出现次数最多的子串

题目:求一个字符串中连续出现次数最多的子串, 请给出分析和代码。



给出一个由小写字母组成的串s和一个不超过s的长度的正整数l,求s所有长度不小于l的字串中在s中不重叠地重复出现次数最多的子串。只要输出这个子串出现的次数就行了。

特别强调:子串不是子序列,必须是从s截出来连续的一段。s也是自身的子串。

例如

s = "abcabc", l = 3,

那么输出2,因为所求的子串是abc。

再例如

s = "ababa", l = 3,

那么输出1,长度不小于3的字串包括aba, bab, abab, baba, ababa。其中后面四个显然都只出现一次。前一个aba和后一个aba重叠了一个a,所以只能算不重叠地出现了一次。

实现接口

C/C++ code
   
   
int solve( const char * s, int l);

s和l意思如上。通过返回值返回答案。
*/
#include
< stdio.h >

int solve( const char * s, int l);
int main()
{
char s[] = " jfurhgyaopylhijknmbjhutyaopglhkyinjbaopfjguthfaopkbmvnchfaop " ;
int l;
// printf("enter characters/n");
// scanf("%s",s);
printf( " enter l/n " );
scanf(
" %d " , & l);
printf(
" %d " ,solve(s,l));
getchar();getchar();
return 0 ;
}

int solve( const char * s, int l)
{
int max = 1 ,c;
int i,j,k,t = 0 ,lenth,take,ls,p,t1 = 0 ;
// ls为原始字符串的长度
int a[ 10000 ];
// 读取样本字符串的数组
int count1 = 0 ,count[ 10000 ] = { 0 };
// count数组记录样本字符串在原字符串中出现的次数,当其为0是表示只有一个

int temp;

for (ls = 0 ;s[ls];ls ++ ) // 计算原字符串长度
;

for (i = 0 ;i <= ls - l;i ++ ) // 此处i用来控制启示位置,ls-l表示样本字符串活动范围
{
for (lenth = l;lenth <= ls - i;lenth ++ ) // lenth表示样本字符串的长度
{
for (take = i,p = 0 ;take < lenth + i;take ++ ,p ++ ) // 读取起始位置为i长度为lenth的字符串
{
a[p]
= s[take];printf( " %c " ,a[p]);
}
printf(
" /n " );
t1
++ ; // 为数组count序号

for (j = 0 ;j <= ls - lenth;) // 在原字符串中开始寻找一样的样本字符串
{
for (k = j,p = 0 ;k < lenth + j;k ++ ,p ++ )
{
if (a[p] == s[k])
{
count1
++ ; // 统计在同样长度下相同字符的个数
}
else
{
count1
= 0 ;
break ;
}
}

if (count1 == lenth) // 成立则表明有相同的字符串
{
t
++ ; // t为次数
// count[t1]=t;printf("t1=%d %d/n",t1,count[t1]);
if (t > max) max = t;
j
= j + lenth; // 避免出现重叠例如"ababa" 只能算出现一次"aba"
count1 = 0 ;
}

else j ++ ;
}printf(
" /n " );
t
= 0 ; // 使次数归零
}
}

/* for (i=0;i<t1;i++)//从大到小排序
{
for (j=0;j<t1;j++)
{
if (count[j]<count[j+1])
{
temp=count[j];
count[j]=count[j+1];
count[j+1]=temp;
}
// printf("%d",count[j]);
}
//printf("/n");
}
*/
printf(
" 最大次数为%d/n " ,max);
return 0 ; // count[0]; // 返回最大的次数
}






上次看到类似的题
将abcbcbcabc转成
// abcbcbcabc
// bcbcbcabc
// cbcbcabc
// bcbcabc
// cbcabc
// bcabc
// cabc
// abc
// bc
// c
C/C++ code
   
   

#include
< iostream >
#include
< string >
#include
< vector >

using namespace std;

pair
< int , string > fun( const string & str)
{
vector
< string > substrs;
int maxcount = 1 , count = 1 ;
string substr;
int i,len = str.length();
for (i = 0 ; i < len; ++ i)
substrs.push_back(str.substr(i, len
- i));

for (i = 0 ; i < len; ++ i)
{
count
= 1 ;
for ( int j = i + 1 ; j < len; ++ j)
{
if (substrs[i].substr( 0 , j - i) == substrs[j].substr( 0 , j - i))
{
++ count;
for ( int k = j + (j - i); k < len; k += j - i)
{
if (substrs[i].substr( 0 , j - i) == substrs[k].substr( 0 , j - i))
++ count;
else
break ;
}
if (count > maxcount)
{
maxcount
= count;
substr
= substrs[i].substr( 0 , j - i);
}
}
}
}

return make_pair(maxcount, substr);
}

int main()
{
string str;
pair
< int , string > rs;
while (cin >> str)
{
rs
= fun(str);
cout
<< rs.second << ' : ' << rs.first << ' /n ' ;
}

return 0 ;
}




更多内容请见:
http://topic.csdn.net/u/20080424/11/886e2197-4bc7-42b1-a273-0c2915729f0b.html

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值