Problem Solving/문제풀이

[BOJ] 10840 구간 성분

Ryute 2018. 7. 19. 14:39

진짜 어이없게 풀었다. 처음에는 해싱인지 모르고 $O(n^3)$에 최적화 생각했는데

롤링 해시 구현하기 귀찮아서 그냥 알파벳에 숫자 하나씩 할당해 놓고 다 더한다음에 일치하면 okay라고 판별했다.

int 범위 내에서 하니까 충돌나길래 long long 범위까지 늘렸더니 어셉됐다 ㅋㅋㅋㅋㅋㅋ

결과적으로는 $O(n^2 lg n) 풀이임.


1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
#include <cstdio>
#include <algorithm>
#include <cstring>
#include <vector>
#include <cassert>
 
using namespace std;
 
typedef long long ll;
 
ll prime[]={1553543355441,6835413543356,341238467843,5846878493734,255654493854,4385646055553,29333247254,56842665466513,6562454444132,33264680204,97185465094454,8937264644356,85143166465423,78565446465415,98746146556215,8547654654856,841537879874131,7293864657254,9814378779242,74464658844594,24495564314761,186549524066569,39665654465873,481654731322,41565458484,13646542908};
 
int ctoi(char x)
{
    return x-'a';
}
 
int main()
{
    char a[1505],b[1505];
    scanf("%s %s",a,b);
    int alen=strlen(a);
    int blen=strlen(b);
 
    /*for(int i=0;i<26;i++)
        assert(isPrime(prime[i]));*/
 
    ll asum[1505]={},bsum[1505]={};
    for(int i=1;i<=alen;i++)
        asum[i]=asum[i-1]+prime[ctoi(a[i-1])];
    for(int i=1;i<=blen;i++)
        bsum[i]=bsum[i-1]+prime[ctoi(b[i-1])];
    vector<ll> V;
    for(int i=1;i<=alen;i++)
        for(int j=i;j<=alen;j++)
            V.push_back(asum[j]-asum[i-1]);
    sort(V.begin(),V.end());
    for(int i=blen;i>=1;i--)
    {
        for(int j=0;j<=blen-i;j++)
        {
            if(binary_search(V.begin(),V.end(),bsum[i+j]-bsum[j]))
            {
                printf("%d",i);
                return 0;
            }
        }
    }
    printf("0");
    return 0;
}
 
cs