제출 #165411

#제출 시각아이디문제언어결과실행 시간메모리
165411egekabasSavez (COCI15_savez)C++14
120 / 120
972 ms13560 KiB
#include <bits/stdc++.h> #define ff first #define ss second #define pb push_back #define mp make_pair using namespace std; typedef long long ll; typedef unsigned long long ull; typedef long double ld; typedef pair<ll, ll> pll; typedef pair<ull, ull> pull; typedef pair<ll, ll> pii; typedef pair<ld, ld> pld; ll n; ll lps[100009]; map<string, ll> dp; void func(string s){ int len = 0; int i = 1; while(i < s.size()){ if(s[i] == s[len]){ ++len; lps[i] = len; ++i; } else if(len > 0) len = lps[len-1]; else{ lps[i] = 0; ++i; } } } int main() { //freopen("in.txt", "r", stdin); //freopen("out.txt", "w", stdout); cin >> n; ll ans = 0; for(ll i = 0; i < n; ++i){ string s; cin >> s; func(s); ll cur = 1+dp[s]; ll len = lps[s.size()-1]; while(len > 0){ cur = max(cur, 1+dp[s.substr(0, len)]); len = lps[len-1]; } dp[s] = cur; ans = max(ans, cur); } cout << ans << "\n"; }

컴파일 시 표준 에러 (stderr) 메시지

savez.cpp: In function 'void func(std::__cxx11::string)':
savez.cpp:20:13: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
     while(i < s.size()){
           ~~^~~~~~~~~~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...