| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1867 人关注过本帖
标题:最长公共子串,二分+哈希,求帮忙查错
只看楼主 加入收藏
海韵
Rank: 1
等 级:新手上路
帖 子:4
专家分:0
注 册:2011-7-24
结帖率:0
收藏
已结贴  问题点数:20 回复次数:11 
最长公共子串,二分+哈希,求帮忙查错
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
int hash1[3938]={0},hash2[4128]={0},hash3[2084]={0},hash4[3030]={0};
long long i,j,n,len,l1,l2,k,flag=0;
char s1[100001],s2[100001];
void h(int a,int b)  //将对应的子串处理成27进制数,存入4个哈希数组
{
     long long i,y=0,z=3937*4127*2083*3029;
     for (i=a;i<=b;i++)
     {
         y*=27;
         y+=s1[i]-'a'+1;
         y%=z;
     }
     hash1[y%3937]=1;
     hash2[y%4127]=1;
     hash3[y%2083]=1;
     hash4[y%3029]=1;
}
long long num(int a,int b)  //算出匹配串对应的27进制数
{
    long long i,y=0,z=3937*4127*2083*3029;
    for (i=a;i<=b;i++)
    {
         y*=27;
         y+=s2[i]-'a'+1;
         y%=z;
    }
    return y;
}
void resehash()  //重设hash数组
{
     for (i=0;i<=2083;i++)
     {
         hash1[i]=0;
         hash2[i]=0;
         hash3[i]=0;
         hash4[i]=0;
     }
     for (i=2084;i<=3029;i++)
     {
         hash1[i]=0;
         hash2[i]=0;
         hash4[i]=0;
     }
     for (i=3030;i<=3937;i++)
     {
         
         hash1[i]=0;
         hash2[i]=0;
     }
     for (i=3938;i<=4127;i++)
         hash2[i]=0;
         
}
void guess(int start,int end)  //二分查找
{
     long long i,j,w,x,y,z=0;
     if (flag>0) return;
     if (start==end) {flag=1; printf("%d\n",start);return;  }
     x=(start+end)/2; w=(start+end)%2; x+=w; //x为阶段中间值
     for (i=0;i<=l1-x;i++)  
       h(i,i+x-1);          //哈希
     for (i=0;i<=l2-x;i++)  //在s2中匹配
     {
         y=num(i,i+x-1);   //算出匹配串对应的27进制数
         if (hash1[y%3937]>0&&hash2[y%4127]>0&&hash3[y%2083]>0&&hash4[y%3029]>0)  //4个哈希数组全部符合
         {
           z=1; break;  //可以达到
         }
     }
     if (z==1) { resehash(); guess(x,end); return; }  //往大的方向找
     guess(start,x-1);  //否则往小的方向找
     return;
}

int main()
{
    scanf("%s",s1);
    scanf("%s",s2);
    l1=strlen(s1); l2=strlen(s2);
    if (l1<l2) k=l1;
      else k=l2;
    guess(0,k);
    system("pause");
}
手动生成的小数据都过了,大数据WA的WA,TLE的TLE。
附加两个数据:

输入1:
mbmkdvlxagiduexvgrkjnmluxyauzlblprxwojnkyawndlgntrusgxxghduigmknrseoiencjxqswgcpaahrbyszeckvqsruzxxkmsyugxoesnzuswjgrgmjmxltgstrztewlhxuegcmgymqbwdbjrpogzdpudbelixqjlycejuazmjizvfyanhbeizayyndxeujjfunhvilpudqybbaxknipdfujlwqdmzbcknxjbfdzmxgxkxabpdrcbqjgjwxotcmtvdflpjehhjlcptyykrzdyqjbyxnkuptdgapvhylgwhvrlmiflpgovjcgzzlbwkxndudltcqkfpmoqasmttmuxvyytcujloqubbuojptptrvadelpgoctoaxzagurdnkrlbopnxajvuwjpfyvbztwbiwuvabidqcvwbxqjaylvlfshtdntejotzwbeyqdkacckvimdrqnwqhvfcgakkksgqscgfjdkxkxbovptmuhhmznbubvbravztspakuigjqnztciwdayevhjwjhslxvwnytwqxycjphlasiprmnirlnghsqvxiemizlexoxyvfmcmhabfvvaxcxxteqofmesakcyekmsuihbxkyvaqyppexzwruktftakfdvzuthbgifvluiudxmqkxpvegwijnndoobluyyvangybetmsqaakjfxvzvzbgkrtn
mbmkdvlxagiduexvgrkjnmluxyauzlblprxwojnkyawndlgntrusgxxghduigmknrseoiencjxqswgcpaahrbyszeckvqsruzxxkmsyugxoesnzuswjgrgmjmxltgstrztewlhxuegcmgymqbwdbjrpogzdpudbelixqjlycejuazmjizvfyanhbeizayyndxeujjfunhvilpudqybbaxknipdfujlwqdmzbcknxjbfdzmxgxkxabpdrcbqjgjwxotcmtvdflpjehhjlcptyykrzdyqjbyxnkuptdgapvhylgwhvrlmiflpgovjcgzzlbwkxndudltcqkfpmoqasmttmuxvyytcujloqubbuojptptrvadelpgoctoaxzagurdnkrlbopnxajvuwjpfyvbztwbiwuvajidqcvwbxqjaylvlfshtdntejotzwbeyqdkacckvimdrqnwqhvfcgakkksgqscgfjdkxkxbovptmuhhmznbubvbravztspakuigjqnztciwdayevhjwjhslxvwnytwqxycjphlasiprmnirlnghsqvxiemizlexoxyvfmcmhabfvvaxcxxteqofmesakcyekmsuihbxkyvaqyppexzwruktftakfdvzuthbgifvluiudxmqkxpvegwijnndoobluyyvangybetmsqaakjfxvzvzbgkrtn

标准输出:415

输入2:

mmnmnnnmmmnnnnnnmmmmmmmnnmnnmmnnnmmmmnnmmmnnnmnmnnmnmnmmnmmmmnnmnmmmmnnnmnnmmmmnnnmnnmmnmnnmmnmmnnnnmmnnnmmmmmmmmnnmnmmnmmmnmmnnmnmnnnnmmnmnmmnnmmnnmnnnnnnnmnnnmnmnnnmmmnmnnmnmmnnmnmmnmnmmmmnmnnnmmnnnnnnmnmmmnnmmnmnmnmnmnnnmnmmmnmnnmnnmmmnmmnmnnmnnmnmmnnnmmnmnmmmnnmnmnnnmnnmnnnnmmmmnmmmmnmnnnmnnmmmmmnnnmmnmmmnmmnmnnmnnnmmmmnnmmmmmnnnnnnnmmmnnmmnnnnmmmnmmmmmnnmnnmnnmmnnmnnmnmmnnmmmnmmnnmmnnnnmmmnmmnnmmmmnmnnmnmnmmnnmmmmmnmmmmmmnmmnmmnmnmnnnnmnmmmnmnmnnnnmmmmnnmnmmnmmnmmmnmmmnmmnnmmnnmnmnmmmnnmmmnnnnmmnnmmnmmnmnnnnmmmmnmmnnnnmnnnmnnmnnmmnnnnnnmnmmmmnmnnnnnmmmmnmmmnnnnnnmnmmmnmnnmnnnnnmmnnnnmnnnnnmnnmmmmnmnmnnmnmnnnmnnnnmnmnmmmmmnnnnmmmnmmnnmnmnmmnnmnnmmmnnmnmnnmmmnnnmmnmmnnmmnnmnmnnmnnmmmmmmnnnmnmnnmmmnnnnnnnmmnmnmnnnmmmmnnnnnnnmnmmmnmmmmmmmnmmmnmnmmmnmnnmnnmnnnnnmmnmmmmnnnmmmnnmnnnnnnnnnnmmnnnnmnmmmnmmnmnmnmnnmmmnmmnmnmmnnmnmmnnmnmmmmnmnnnmnmnmnnnnnnnmmnmnmnnnmnnmnmnmnnnnmnmmmmnmmmnnnnmmmmmnmmnmmnnmmmnnnnnmnmnnnmmmnnmnmnnnmnnnmnmmnmmmmnnmmnnmmnnnnnnmmmnnnmmmnmnmmnmnnnnnmnmnnmnmnnmmmnmmn
mnnnmnnnmnnmmmmmnmnmmnnmmnmmmnnmnnmmnnnmnnnmnmnmmnnmmnmnmmmnmmnnnmmnmmmnmnnmmnmnnnnnnmnnnnnnmmnnmnnmmmmnnnmmnmnnmmmnmmnmnmmmmmmnmmnnnmmnmmnnmnnmnmnnmmnnmnnnmnnmnnnmnmnnnnnnnnmmmnmmnmmnmnnnnnnmnnmnmmmmmmmnnmnnnmmmnnmmnmnmnmnnnmnmmnmnmnmmmmnmmnnmnnmmnmmnnnmnnmnnmnmmnnmmmmnmmmnmmmnnnmnnmmmnmmmmmmnmmmmmnmmmnmnnmnmmnmnmmnmnnmmnnnnnnmnnnnnmnnmmmmmnmmnnnmnnmmmnnmnmnnmnmnnnmmmnmnmmnnnnmmmmnnmnnmmmmmmnmmmnmmnnmnnmmnmmnmmnmmnmnnnnmmmmmnnnnmmnmmnnnnnnnmmmnnmmnnnmmnnmmmnmnmnmmmnmnnnnmmnmnmmnmnnnmnmmmnnmmmnmmmnmmnnmnmnnnnmmmnmnnmnmmmmmnmmnnnnnnmmmmnnmnmmmmnmnnnnnmmnmmmmmnnmmmmnmnnmmmnnnmmmmnmnmmmnnmmnmnmnmmnnnmmnnmmmmnnmmnnmnmmmmmmnnmmnmnmnmmnnmnnmmnmnnnmnnmmnnmmnmmnnmnnnnnnnmnmnnmnnnnnnmnmmnmmmmnnnmmmmmmmmnmnnmmmnmnnnnnnmnnnnnnmmnnmnnmmnmmnmmnnmmmnmnnmnnmmmmmnnmmmnmnmnmmnmnmnmmmmnmmnnmnmmmnnmmmmnnnmmnmnmmnnmnmmmnmmmmnnmnmnnnmmmmmmnmnnnmnnmmmnmnnnnmmnnnnnnnmnnnmmnnmmnnmnnnnnmmmnmnmnmnnmnmnnmmnnnnnmnnnnnmnnnnmmnnnnnmmmnmmmmnnmmnmnnnmmnmmmmnnmmnnnnnmnnnmmnmnnnnmnnmnnmmnmnmmmmmmmmnnmmnmmnnnmnmmnnnnmnn

标准输出:20
搜索更多相关主题的帖子: long 2083 include 
2011-07-24 21:05
pcbaichi
Rank: 9Rank: 9Rank: 9
等 级:蜘蛛侠
帖 子:486
专家分:1185
注 册:2010-11-13
收藏
得分:5 
哪里的ACM,数据这么大,晕

免费赠送河蟹一只
2011-07-24 21:37
海韵
Rank: 1
等 级:新手上路
帖 子:4
专家分:0
注 册:2011-7-24
收藏
得分:0 
偶们学校的OJ啊,真的不知道哪里错了。如果哪位神犇有空且有闲情逸致就帮我看看吧,万分感谢。
2011-07-25 11:25
y515382
Rank: 2
等 级:论坛游民
帖 子:38
专家分:16
注 册:2011-7-9
收藏
得分:5 
一眼望过去,头晕了
2011-07-25 11:51
pcbaichi
Rank: 9Rank: 9Rank: 9
等 级:蜘蛛侠
帖 子:486
专家分:1185
注 册:2010-11-13
收藏
得分:0 
回复 3楼 海韵
能不能把原题发过来

免费赠送河蟹一只
2011-07-25 16:39
为我留住记忆
Rank: 4
来 自:北京
等 级:业余侠客
帖 子:130
专家分:226
注 册:2011-4-30
收藏
得分:5 



   看得都头晕。。。

学习c是为了自己更强大。。。
2011-07-25 17:03
sunyh1999
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:版主
威 望:14
帖 子:1178
专家分:3032
注 册:2009-5-17
收藏
得分:5 
这个数据是最大的吗?

欢迎来到我的博客:http://blog..cn/noisunyuhong
2011-07-25 19:18
sunyh1999
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:版主
威 望:14
帖 子:1178
专家分:3032
注 册:2009-5-17
收藏
得分:0 
这题的正解应该是后缀数组

欢迎来到我的博客:http://blog..cn/noisunyuhong
2011-07-25 19:27
海韵
Rank: 1
等 级:新手上路
帖 子:4
专家分:0
注 册:2011-7-24
收藏
得分:0 
题目描述

给定两个字符串(长度小于等于10^5),求最长公共子串的长度

输入
共两行,分别为一个字符串

输出
一个数,即最长公共子串的长度

样例输入
whatislocalbus
localbusiswhat

样例输出
8





主题帖中那个数据不是最大的,但也比较大了
后缀数组不会写啊,二分+哈希应该对的几率比较大的,可我到底哪错了呢?
2011-07-26 11:50
sunyh1999
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:版主
威 望:14
帖 子:1178
专家分:3032
注 册:2009-5-17
收藏
得分:0 
感觉是你哈希出了问题

欢迎来到我的博客:http://blog..cn/noisunyuhong
2011-07-26 12:34
快速回复:最长公共子串,二分+哈希,求帮忙查错
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.029823 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved