QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#807847#7700. Split Decisionsucup-team3723#AC ✓40ms30356kbC++173.0kb2024-12-10 13:05:372024-12-10 13:05:49

Judging History

你现在查看的是最新测评结果

  • [2024-12-10 13:05:49]
  • 评测
  • 测评结果:AC
  • 用时:40ms
  • 内存:30356kb
  • [2024-12-10 13:05:37]
  • 提交

answer

#include <bits/stdc++.h>
#define dbg(x) cerr << #x << ':' << (x) << endl; 
using namespace std;
using ll = long long;
using ld = long double;
#define ALL(x) x.begin(),x.end()

int solve(vector<string>& s, int n) {
    int sz = 26;

    vector<vector<int>> z_hash(s[0].size(),vector<int>(sz));
    mt19937 mt_random(0);
    for (int i = 0; i < s[0].size(); i++) {
        for (int j = 0; j < sz; j++) {
            z_hash[i][j] = mt_random();
        }
    }
    vector<vector<int>> h(s[0].size(), vector<int>(n));
    for (int i = 0; i < s[0].size()-1; i++) {
        for (int j = 0; j < n; j++) {
            for (int k = 0; k < s[0].size(); k++) {
                if (i == k || i+1 == k) continue;
                h[i][j] ^= z_hash[k][s[j][k]-'A'];
            }
        }
    }

    auto func = [](char a, char b){
        return (a-'A')*26 + (b-'A');
    };

    auto check = [&](int i, int j, int k)->bool{
        for (int l = 0; l < s[0].size(); ++l) {
            if (l == k || l == k+1) continue;
            if (s[i][l] != s[j][l]) return false;
        }
        if (s[i][k] == s[j][k] || s[i][k+1] == s[j][k+1]) return false;
        return true;
    };

    vector<vector<vector<int>>> v(s[0].size(), vector<vector<int>>(sz*sz, vector<int>(sz*sz)));
    for (int i = 0; i < s[0].size()-1; ++i) {
        
        for (int j = 0; j < n; ++j) {
            int tmp1 = func(s[j][i],s[j][i+1]);
            for (int k = j+1; k < n; ++k) {
                int tmp2 = func(s[k][i],s[k][i+1]);
                // if (h[i][j] != h[i][k]) continue;
                if (!check(j,k,i)) continue;
                if (tmp1 == tmp2) continue;
                if (tmp1 < tmp2) v[i][tmp1][tmp2]++;
                else v[i][tmp2][tmp1]++;
            }
        }
    }

    int ans = 0;
    for (int i = 0; i < n; i++) {
        for (int j = i+1; j < n; j++) {
            for (int k = 0; k < s[0].size()-1; k++) {
                int tmp1 = func(s[i][k],s[i][k+1]);
                int tmp2 = func(s[j][k],s[j][k+1]);
                // if (h[k][i] != h[k][j]) continue;
                if (!check(i,j,k)) continue;
                if (tmp1 == tmp2) continue;
                
                if (tmp1 < tmp2) {
                    if (v[k][tmp1][tmp2] == 1) {
                        ++ans;
                        break;
                    }
                }
                else {
                    if (v[k][tmp2][tmp1] == 1) {
                        ++ans;
                        break;
                    }
                }
            }
        }
    }

    return ans;
}

int main()
{
    int n;
    cin >> n;

    vector<string> s(n);
    for (int i = 0; i < n; i++) cin >> s[i];

    vector<vector<string>> t(21);
    for (int i = 0; i < n; i++) t[s[i].size()].emplace_back(s[i]);
    int ans = 0;
    for (int i =  3; i <= 20; i++) {
        if (t[i].empty()) continue;
        ans += solve(t[i], t[i].size());
    }

    cout << ans << endl;
}

詳細信息

Test #1:

score: 100
Accepted
time: 0ms
memory: 12184kb

input:

5
CELL
GULL
GUSH
HALL
HASH

output:

2

result:

ok single line: '2'

Test #2:

score: 0
Accepted
time: 22ms
memory: 17592kb

input:

1000
ABSALOM
ACRATIA
AKHOOND
ALIBAMU
AMUSIVE
AGONIZE
ACOCOTL
ACTINON
ABELITE
ADVISAL
ALBETAD
AMAKEBE
ANASAZI
AMUCHCO
ADDENDA
AMESITE
ALIENEE
ADRENIN
ACERATE
AKERITE
AMPELIS
ABABDEH
ALCIDAE
AGRANIA
ALASTER
AMERISM
AMILOUN
AMYGDAL
ALUNDUM
ACHOLIC
ALTHAEA
ACIDIFY
AMNESTY
ABBOTCY
AMBALAM
AMENITY
AEOLISM...

output:

621

result:

ok single line: '621'

Test #3:

score: 0
Accepted
time: 3ms
memory: 17572kb

input:

14
ALTO
AFRO
AGENT
CAMP
CHEAP
CHESS
CLAP
CORSAGE
COURAGE
EXTINCT
EXTRACT
SCENT
STEEP
CHUMP

output:

7

result:

ok single line: '7'

Test #4:

score: 0
Accepted
time: 0ms
memory: 12236kb

input:

4
ABCD
AEFD
AGHD
AIJD

output:

6

result:

ok single line: '6'

Test #5:

score: 0
Accepted
time: 4ms
memory: 13960kb

input:

3
ABABA
AABBA
ABBAA

output:

2

result:

ok single line: '2'

Test #6:

score: 0
Accepted
time: 2ms
memory: 14044kb

input:

3
AAAAA
ABBAA
AABBA

output:

2

result:

ok single line: '2'

Test #7:

score: 0
Accepted
time: 3ms
memory: 12068kb

input:

8
ABBA
ACCA
AABB
AACC
DBBD
DCCD
EEBB
EECC

output:

0

result:

ok single line: '0'

Test #8:

score: 0
Accepted
time: 4ms
memory: 12124kb

input:

6
ABBA
ACCA
AABB
AACC
DBBD
DCCD

output:

1

result:

ok single line: '1'

Test #9:

score: 0
Accepted
time: 0ms
memory: 12040kb

input:

4
ABBA
ACCA
AABB
AACC

output:

2

result:

ok single line: '2'

Test #10:

score: 0
Accepted
time: 0ms
memory: 14044kb

input:

4
ABBA
ACCA
ABBAA
ACCAA

output:

2

result:

ok single line: '2'

Test #11:

score: 0
Accepted
time: 3ms
memory: 23212kb

input:

100
CCBAEADDE
CABCDE
EDBCBEC
BAEE
EDADBBEBA
BCAEC
EABCE
ADECB
BEACCDECB
DEDE
BADDDAE
BBBADBAED
CDEBBC
CAADCDEE
EECD
EAAAABA
EAADAAC
DDBACADDB
DCCCCCB
AADEDBC
ACBAACBDB
CDAAACCBC
EEDCB
CCEEBCEEE
AEAABE
BEDEAAACB
DAECDB
CACBBEB
ABEBED
ECEDAEE
EDCEBBBADB
BEACE
EDBAADAE
AABADC
EBAA
CDED
ADABEA
CBACCBC
A...

output:

4

result:

ok single line: '4'

Test #12:

score: 0
Accepted
time: 11ms
memory: 23272kb

input:

20
AABCC
BADCCCBA
ADCEECBB
DAEEDCB
EAAC
CDCEAEADC
ADBBCDBBCA
BBCABBECAE
CEBAEAEB
CCAAB
EEDADEEB
EADA
CBBEA
ABBDDCC
BABADDA
AEBDBCDBAD
ACCCDDEAB
AEDADEBA
BCDED
DBAB

output:

1

result:

ok single line: '1'

Test #13:

score: 0
Accepted
time: 7ms
memory: 23228kb

input:

250
AEGDGEAB
GGEG
BEEFFEDDF
BBCA
EGBC
BABFDDAFA
GGACGCCCBD
DBFBF
DDDCDG
FAGAED
FFBBAFCBF
EAAEEEAAB
GDAGBA
AEBFFAD
EGBGBBAAA
FFGEGC
DDBGAGADB
EDEBB
EABGBGF
EFBEDBGD
BFGGD
CDGB
CCEGABGFGB
ACEFGEEBA
GDAC
GCEDAFBBA
BFEFAFBGAA
AEGD
GGEACB
CEFBGFAA
GAADFG
ADBD
EABBGA
FFFCE
FDEGGFAAD
AEEFBEE
DCDCFFBD
ACFDC...

output:

39

result:

ok single line: '39'

Test #14:

score: 0
Accepted
time: 15ms
memory: 23248kb

input:

30
CEBCBABB
EADCEC
CADEDDCBBB
CAAE
BBDCCEBEEA
DBABADCAAA
ACCDCECE
CBBEDCCECA
EACDDBB
ECCCCDB
BCDBDAECA
DABD
BECDAEE
ACCBEBEA
BBBDCBEAE
DACCEDB
BEEDBDB
ABBAACCDAA
DCBEB
EECB
ADEE
ADEBCEDCBB
ADADAECE
DBCBD
BBBE
AEDEA
AEAADD
EAAEBE
EBBA
ABCA

output:

0

result:

ok single line: '0'

Test #15:

score: 0
Accepted
time: 21ms
memory: 23204kb

input:

40
CABBD
BAABEA
ADAEABCD
BDCDEECACB
DBABEB
ECDBAAEE
EDABABCEAB
DBEADCADAC
BBEBADBCC
AADEBBCB
CBAAACBEAE
BDAC
DCDCACD
BACABDBCCA
CEBEEEDDB
BACC
AEABCAAC
ABECDDDDBC
CADECB
EAAAAAAE
BDBECEEDBC
AECB
CABAECCE
BCBAA
DCCEBB
ECCBEEC
EECBEABE
CDEAD
DBABA
BDAAED
BCDEBCADEC
BBCDBCAB
EBDAE
DEEACCB
ECACDAA
BCBCC...

output:

1

result:

ok single line: '1'

Test #16:

score: 0
Accepted
time: 0ms
memory: 10452kb

input:

7
ABC
AEF
BAB
BEF
ABA
ACA
AAB

output:

7

result:

ok single line: '7'

Test #17:

score: 0
Accepted
time: 8ms
memory: 30356kb

input:

642
AARON
ABANDONED
ABERDEEN
ABILITIES
ABILITY
ABLE
ABORIGINAL
ABORTION
ABOUT
ABOVE
ABRAHAM
ABROAD
ABSENCE
ABSENT
ABSOLUTE
ABSOLUTELY
ABSORPTION
ABSTRACT
ABSTRACTS
ABUSE
ACADEMIC
ACADEMICS
ACADEMY
ACCENT
ACCEPT
ACCEPTABLE
ACCEPTANCE
ACCEPTED
ACCEPTING
ACCEPTS
ACCESS
ACCESSED
ACCESSIBILITY
ACCESSIBLE...

output:

240

result:

ok single line: '240'

Test #18:

score: 0
Accepted
time: 40ms
memory: 23184kb

input:

1499
AAAAAAAAAA
AAAAABAAAA
AAAAACAAAA
AAAAADAAAA
AAAAAEAAAA
AAAAAFAAAA
AAAAAGAAAA
AAAAAHAAAA
AAAAAIAAAA
AAAAAJAAAA
AAAAAKAAAA
AAAAALAAAA
AAAAAMAAAA
AAAAANAAAA
AAAAAOAAAA
AAAAAPAAAA
AAAAAQAAAA
AAAAARAAAA
AAAAASAAAA
AAAAATAAAA
AAAAAUAAAA
AAAAAVAAAA
AAAAAWAAAA
AAAAAXAAAA
AAAAAYAAAA
AAAAAZAAAA
AAAABAAAA...

output:

211250

result:

ok single line: '211250'