Chinaunix首页 | 论坛 | 博客
  • 博客访问: 1698401
  • 博文数量: 210
  • 博客积分: 10013
  • 博客等级: 上将
  • 技术积分: 2322
  • 用 户 组: 普通用户
  • 注册时间: 2008-09-25 15:56
文章分类

全部博文(210)

文章存档

2011年(34)

2010年(121)

2009年(37)

2008年(18)

我的朋友

分类: C/C++

2010-07-05 20:05:59


#include "stdafx.h"
#include<iostream>
#include<string>
#include<math.h>
#include<vector>

using namespace std;
pair<int,string> getMaxSub(string &str){
    int len = str.length();
    vector<string> substrs;
    for(int i = 0 ; i < len ; i ++){
        cout<<str.substr(i,len-i)<<endl;
        substrs.push_back(str.substr(i,len-i));
    }
    int maxcount = 1;
    int count = 1;
    string substrtmp;
    for(int i = 0 ; i < len ; i ++){
        for(int j = i+1;j < len ; j ++){
            count = 1;
            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;
                    substrtmp = substrs[i].substr(0,j-i);
                }
            }
        }
    }
    return make_pair(maxcount,substrtmp);
}
int _tmain(int argc, _TCHAR* argv[])
{
    string str("abcabcabc");
    pair<int,string> rs;
    rs = getMaxSub(str);
    cout<<rs.second<<rs.first<<endl;
    return 0;
}


abcabcabac

bcabcabc

cabcabc

abcabc

bcabc

cabc

abc

bc

c

循环比较第i个子串和j个子串的前面j-i个字符的异同,相同继续循环比较第k=j+j-i到第len,以j-i为步长的前面j-i个字符的异同。

阅读(862) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~