{
  "question": "A boy named Ayrat lives on planet AMI-1511. Each inhabitant of this planet has a talent. Specifically, Ayrat loves running, moreover, just running is not enough for him. He is dreaming of making running a real art.\n\nFirst, he wants to construct the running track with coating t. On planet AMI-1511 the coating of the track is the sequence of colored blocks, where each block is denoted as the small English letter. Therefore, every coating can be treated as a string.\n\nUnfortunately, blocks aren't freely sold to non-business customers, but Ayrat found an infinite number of coatings s. Also, he has scissors and glue. Ayrat is going to buy some coatings s, then cut out from each of them exactly one continuous piece (substring) and glue it to the end of his track coating. Moreover, he may choose to flip this block before glueing it. Ayrat want's to know the minimum number of coating s he needs to buy in order to get the coating t for his running track. Of course, he also want's to know some way to achieve the answer.\n\n\n-----Input-----\n\nFirst line of the input contains the string s\u00a0\u2014 the coating that is present in the shop. Second line contains the string t\u00a0\u2014 the coating Ayrat wants to obtain. Both strings are non-empty, consist of only small English letters and their length doesn't exceed 2100.\n\n\n-----Output-----\n\nThe first line should contain the minimum needed number of coatings n or -1 if it's impossible to create the desired coating.\n\nIf the answer is not -1, then the following n lines should contain two integers x_{i} and y_{i}\u00a0\u2014 numbers of ending blocks in the corresponding piece. If x_{i} \u2264 y_{i} then this piece is used in the regular order, and if x_{i} > y_{i} piece is used in the reversed order. Print the pieces in the order they should be glued to get the string t.\n\n\n-----Examples-----\nInput\nabc\ncbaabc\n\nOutput\n2\n3 1\n1 3\n\nInput\naaabrytaaa\nayrat\n\nOutput\n3\n1 1\n6 5\n8 7\n\nInput\nami\nno\n\nOutput\n-1\n\n\n\n-----Note-----\n\nIn the first sample string \"cbaabc\" = \"cba\" + \"abc\".\n\nIn the second sample: \"ayrat\" = \"a\" + \"yr\" + \"at\".",
  "solution": "#include <iostream>\n#include <vector>\n#include <string>\n#include <algorithm>\n\nusing namespace std;\n\nint main() {\n    string s, t;\n    cin >> s >> t;\n    \n    vector<pair<int, int>> substrings;\n    int i = 0;\n    while (i < t.size()) {\n        int max_sub_len = 0;\n        string max_sub = \"\";\n        for (int j = i; j <= t.size(); ++j) {\n            string sub = t.substr(i, j - i);\n            if (s.find(sub) != string::npos || s.find(string(sub.rbegin(), sub.rend())) != string::npos) {\n                if (sub.length() > max_sub_len) {\n                    max_sub_len = sub.length();\n                    max_sub = sub;\n                }\n            } else {\n                break;\n            }\n        }\n        if (max_sub_len == 0) {\n            break;\n        }\n        substrings.push_back(make_pair(max_sub_len, i));\n        i += max_sub_len;\n    }\n    \n    int n = substrings.size();\n    vector<pair<int, int>> coatings;\n    for (const auto& sub : substrings) {\n        string sub_str = t.substr(sub.second, sub.first);\n        if (s.find(sub_str) != string::npos) {\n            int start = s.find(sub_str) + 1;\n            coatings.push_back(make_pair(start, start + sub_str.size() - 1));\n        } else {\n            string rev_sub_str = string(sub_str.rbegin(), sub_str.rend());\n            int start = s.find(rev_sub_str) + rev_sub_str.size();\n            coatings.push_back(make_pair(start, start - rev_sub_str.size() + 1));\n        }\n    }\n    \n    if (n == 0 || substrings.back().second + substrings.back().first != t.size()) {\n        cout << -1 << endl;\n    } else {\n        cout << n << endl;\n        for (const auto& coat : coatings) {\n            cout << coat.first << \" \" << coat.second << endl;\n        }\n    }\n    \n    return 0;\n}\n",
  "question_2": "You are given a tree consisting of $n$ vertices. A number is written on each vertex; the number on vertex $i$ is equal to $a_i$.\n\nLet's denote the function $g(x, y)$ as the greatest common divisor of the numbers written on the vertices belonging to the simple path from vertex $x$ to vertex $y$ (including these two vertices). Also let's denote $dist(x, y)$ as the number of vertices on the simple path between vertices $x$ and $y$, including the endpoints. $dist(x, x) = 1$ for every vertex $x$.\n\nYour task is calculate the maximum value of $dist(x, y)$ among such pairs of vertices that $g(x, y) > 1$.\n\n\n-----Input-----\n\nThe first line contains one integer $n$ \u2014 the number of vertices $(1 \\le n \\le 2 \\cdot 10^5)$.\n\nThe second line contains $n$ integers $a_1$, $a_2$, ..., $a_n$ $(1 \\le a_i \\le 2 \\cdot 10^5)$ \u2014 the numbers written on vertices.\n\nThen $n - 1$ lines follow, each containing two integers $x$ and $y$ $(1 \\le x, y \\le n, x \\ne y)$ denoting an edge connecting vertex $x$ with vertex $y$. It is guaranteed that these edges form a tree.\n\n\n-----Output-----\n\nIf there is no pair of vertices $x, y$ such that $g(x, y) > 1$, print $0$. Otherwise print the maximum value of $dist(x, y)$ among such pairs.\n\n\n-----Examples-----\nInput\n3\n2 3 4\n1 2\n2 3\n\nOutput\n1\n\nInput\n3\n2 3 4\n1 3\n2 3\n\nOutput\n2\n\nInput\n3\n1 1 1\n1 2\n2 3\n\nOutput\n0",
  "solution_2": "#include <iostream>\n#include <vector>\n#include <algorithm>\n#include <cmath>\n#include <map>\n#include <queue>\n#include <set>\n\nusing namespace std;\n\nconst int MAXN = 200000;\nconst int MAXA = 200000;\n\nvector<int> primes;\nvector<int> a[MAXN];\nvector<int> adj[MAXN];\nint n;\nbool z = true;\nint answer = 1;\n\nvoid sieve() {\n    vector<bool> is_prime(MAXA + 1, true);\n    for (int i = 2; i <= MAXA; i++) {\n        if (is_prime[i]) {\n            primes.push_back(i);\n            for (int j = i * 2; j <= MAXA; j += i) {\n                is_prime[j] = false;\n            }\n        }\n    }\n}\n\nvoid readInput() {\n    cin >> n;\n    vector<int> values(n);\n    int sum_values = 0;\n    for (int i = 0; i < n; i++) {\n        cin >> values[i];\n        sum_values += values[i];\n    }\n    if (sum_values == n) {\n        z = false;\n    }\n    for (int i = 0; i < n; i++) {\n        int x = values[i];\n        for (int p : primes) {\n            if (p * p > x) break;\n            if (x % p == 0) {\n                a[i].push_back(p);\n                while (x % p == 0) {\n                    x /= p;\n                }\n            }\n        }\n        if (x > 1) {\n            a[i].push_back(x);\n        }\n    }\n    for (int i = 0; i < n - 1; i++) {\n        int x, y;\n        cin >> x >> y;\n        adj[x - 1].push_back(y - 1);\n        adj[y - 1].push_back(x - 1);\n    }\n}\n\nint bfs(int start, int prime) {\n    vector<int> dist(n, -1);\n    queue<int> q;\n    q.push(start);\n    dist[start] = 0;\n    int max_dist = 0;\n    while (!q.empty()) {\n        int u = q.front();\n        q.pop();\n        for (int v : adj[u]) {\n            if (dist[v] == -1 && count(a[v].begin(), a[v].end(), prime)) {\n                dist[v] = dist[u] + 1;\n                max_dist = max(max_dist, dist[v]);\n                q.push(v);\n            }\n        }\n    }\n    return max_dist;\n}\n\nint main() {\n    ios_base::sync_with_stdio(false);\n    cin.tie(nullptr);\n    \n    sieve();\n    readInput();\n    \n    if (!z) {\n        cout << 0 << endl;\n        return 0;\n    }\n    \n    for (int i = 0; i < n; i++) {\n        for (int prime : a[i]) {\n            answer = max(answer, bfs(i, prime) + 1);\n        }\n    }\n    \n    cout << answer << endl;\n    return 0;\n}\n"
}
