Pagini recente » Istoria paginii runda/simulare-cartita-19b/clasament | Cod sursa (job #119539) | Cod sursa (job #2133576) | Cod sursa (job #465466) | Cod sursa (job #1895413)
#include <iostream>
#include <string>
#include <vector>
#include <fstream>
#include <algorithm>
std::vector<int> pattern(std::string s) {
std::vector<int> result(s.size(), 0);
int j = 0;
for(size_t i=1;i<s.size();i++){
while (s[i] != s[j] && j > 0) {
j = result[j - 1];
}
if (s[i] == s[j]) j++;
result[i] = j;
}
return result;
}
std::vector<int> kmp(std::string needle,std::string haystack) {
std::vector<int> p = pattern(needle);
std::vector<int> solution;
size_t j = 0;
for(size_t i = 0;i<haystack.size();i++){
while (haystack[i] != needle[j] && j>0)
j = p[j - 1];
if (haystack[i] == needle[j])
j++;
if (j == needle.size()) {
solution.push_back(i - needle.size() + 1);
}
}
return solution;
}
int main(void) {
std::ifstream in("strmatch.in");
std::string needle;
std::string haystack;
in >> needle >> haystack;
in.close();
std::ofstream out("strmatch.out");
auto sol = kmp(needle, haystack);
out << sol.size() << "\n";
for (int i = 0; i < std::min(1000, (int)sol.size()); i++) {
out << sol[i] << " ";
}
out.close();
return 0;
}