Task: | Z-array |
Sender: | MallocManfred |
Submission time: | 2024-10-31 01:36:56 +0200 |
Language: | C++ (C++11) |
Status: | READY |
Result: | ACCEPTED |
test | verdict | time | |
---|---|---|---|
#1 | ACCEPTED | 0.00 s | details |
#2 | ACCEPTED | 0.00 s | details |
#3 | ACCEPTED | 0.00 s | details |
#4 | ACCEPTED | 0.00 s | details |
#5 | ACCEPTED | 0.00 s | details |
#6 | ACCEPTED | 0.14 s | details |
#7 | ACCEPTED | 0.13 s | details |
#8 | ACCEPTED | 0.14 s | details |
#9 | ACCEPTED | 0.13 s | details |
#10 | ACCEPTED | 0.13 s | details |
#11 | ACCEPTED | 0.00 s | details |
#12 | ACCEPTED | 0.13 s | details |
#13 | ACCEPTED | 0.13 s | details |
Compiler report
input/code.cpp: In function 'int main()': input/code.cpp:4:63: warning: format '%lld' expects argument of type 'long long int', but argument 2 has type '__gnu_cxx::__alloc_traits<std::allocator<int>, int>::value_type' {aka 'int'} [-Wformat=] 4 | #define vout(x) for(int i=0;i<(long long)x.size();i++) printf("%lld ",x[i]); | ^~~~~~~ input/code.cpp:60:5: note: in expansion of macro 'vout' 60 | vout(z_array); | ^~~~ input/code.cpp:4:67: note: format string is defined here 4 | #define vout(x) for(int i=0;i<(long long)x.size();i++) printf("%lld ",x[i]); | ~~~^ | | | long long int | %d
Code
#include <bits/stdc++.h>using namespace std;#define vout(x) for(int i=0;i<(long long)x.size();i++) printf("%lld ",x[i]);#define REP(i,a,b) for (int i = a; i <= b; i++)// g++ <filename>.cpp -g -Wall -Wextra -DDEBUG -o <executable>// copied from: https://codeforces.com/blog/entry/79024// === Debug macro starts here ===int recur_depth = 0;#ifdef DEBUG#define dbg(x) {++recur_depth; auto x_=x; --recur_depth; cerr<<string(recur_depth, '\t')<<"\e[91m"<<__func__<<":"<<__LINE__<<"\t"<<#x<<" = "<<x_<<"\e[39m"<<endl;}#else#define dbg(x)#endiftemplate<typename Ostream, typename Cont>typename enable_if<is_same<Ostream,ostream>::value, Ostream&>::type operator<<(Ostream& os, const Cont& v){os<<"[";for(auto& x:v){os<<x<<", ";}return os<<"]";}template<typename Ostream, typename ...Ts>Ostream& operator<<(Ostream& os, const pair<Ts...>& p){return os<<"{"<<p.first<<", "<<p.second<<"}";}// === Debug macro ends here ===vector<int> z(string s) {int n = s.size();vector<int> z(n);int l = 0;int r = 0;for (int i = 1; i < n; i++){z[i] = max(0,min(z[i-l],r-i+1));while (i+z[i] < n && s[z[i]] == s[i+z[i]]){l = i;r = i+z[i];z[i]++;}}return z;}signed main() {string s;cin >> s;vector<int> z_array = z(s);z_array[0] = s.size();vout(z_array);cout << "\n";return 0;}
Test details
Test 1
Verdict: ACCEPTED
input |
---|
aaaaaaaaaa |
correct output |
---|
10 9 8 7 6 5 4 3 2 1 |
user output |
---|
10 9 8 7 6 5 4 3 2 1 |
Test 2
Verdict: ACCEPTED
input |
---|
ababababab |
correct output |
---|
10 0 8 0 6 0 4 0 2 0 |
user output |
---|
10 0 8 0 6 0 4 0 2 0 |
Test 3
Verdict: ACCEPTED
input |
---|
aabababaaa |
correct output |
---|
10 1 0 1 0 1 0 2 2 1 |
user output |
---|
10 1 0 1 0 1 0 2 2 1 |
Test 4
Verdict: ACCEPTED
input |
---|
ahtqqkhrrn |
correct output |
---|
10 0 0 0 0 0 0 0 0 0 |
user output |
---|
10 0 0 0 0 0 0 0 0 0 |
Test 5
Verdict: ACCEPTED
input |
---|
mqdozmqdoz |
correct output |
---|
10 0 0 0 0 5 0 0 0 0 |
user output |
---|
10 0 0 0 0 5 0 0 0 0 |
Test 6
Verdict: ACCEPTED
input |
---|
aaaaaaaaaaaaaaaaaaaaaaaaaaaaaa... |
correct output |
---|
1000000 999999 999998 999997 9... |
user output |
---|
1000000 999999 999998 999997 9... Truncated |
Test 7
Verdict: ACCEPTED
input |
---|
ababababababababababababababab... |
correct output |
---|
1000000 0 999998 0 999996 0 99... |
user output |
---|
1000000 0 999998 0 999996 0 99... Truncated |
Test 8
Verdict: ACCEPTED
input |
---|
baaaabbabaabbbbaaaabbbababaaba... |
correct output |
---|
1000000 0 0 0 0 1 2 0 3 0 0 1 ... |
user output |
---|
1000000 0 0 0 0 1 2 0 3 0 0 1 ... Truncated |
Test 9
Verdict: ACCEPTED
input |
---|
ltpbdybvcpychbsplyonjfmdtsnqwt... |
correct output |
---|
1000000 0 0 0 0 0 0 0 0 0 0 0 ... |
user output |
---|
1000000 0 0 0 0 0 0 0 0 0 0 0 ... Truncated |
Test 10
Verdict: ACCEPTED
input |
---|
aaaaaaaaaaaaaaaaaaaaaaaaaaaaaa... |
correct output |
---|
1000000 99998 99997 99996 9999... |
user output |
---|
1000000 99998 99997 99996 9999... Truncated |
Test 11
Verdict: ACCEPTED
input |
---|
abaababaab |
correct output |
---|
10 0 1 3 0 5 0 1 2 0 |
user output |
---|
10 0 1 3 0 5 0 1 2 0 |
Test 12
Verdict: ACCEPTED
input |
---|
zzzzzzzzzzzzzzzzzzzzzzzzzzzzzz... |
correct output |
---|
1000000 499999 499998 499997 4... |
user output |
---|
1000000 499999 499998 499997 4... Truncated |
Test 13
Verdict: ACCEPTED
input |
---|
aaaaaaaaaaaaaaaaaaaaaaaaaaaaaa... |
correct output |
---|
1000000 147418 147417 147416 1... |
user output |
---|
1000000 147418 147417 147416 1... Truncated |