[百度面试题]找出字符串中连续出现次数最多的子串

寻找最长连续匹配子串
本文阐述了如何通过穷举后缀子串并比较来找到给定字符串中最长连续匹配子串的过程。
基本算法描述: 
给出一个字符串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个字母匹配. 

如果匹配的并记下匹配次数.如此可以求得最长连续匹配子串. 

int count = 0; 
char sub_str[256]; 

void find_str(char *str) 
{ 
     int str_len = strlen(str); 
     int i, j, k; 
     int tmp_cnt = 0; 
 
     for (i = 0; i < str_len; i++) 
     { 
         for (j = i+1; j < str_len; j++) 
         { 
             int n = j-i;                         //sub string length 
             tmp_cnt = 1; 
             if (strncmp(&str[i], &str[j], n) == 0)   //compare n-lengths strings 
             { 
                 tmp_cnt++;                          //they are equal, so add count 
                 for (k = j+n; k < str_len; k += n)  //consecutive checking 
                 { 
                     if (strncmp(&str[i], &str[k], n) == 0) 
                     { 
                         tmp_cnt++; 
                     } 
                     else 
                         break; 
                 } 
                 if (count < tmp_cnt) 
                 { 
                     count = tmp_cnt; 
                     memcpy(sub_str, &str[i], n); //record the sub string 
                 } 
             } 
         } 
 
     } 
 }


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值