{
  "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": "s = input().strip()\nt = input().strip()\nsubstrings = []\ni = 0\nwhile i < len(t):\n    max_sub_len = 0\n    max_sub = \"\"\n    for j in range(i, len(t) + 1):\n        sub = t[i:j]\n        if sub in s or sub[::-1] in s:\n            if len(sub) > max_sub_len:\n                max_sub_len = len(sub)\n                max_sub = sub\n        else:\n            break\n    if max_sub_len == 0:\n        break\n    substrings.append(max_sub)\n    i += max_sub_len\nn = len(substrings)\ncoatings = []\nfor sub in substrings:\n    if sub in s:\n        coatings.append((s.find(sub) + 1, s.find(sub) + len(sub)))\n    else:\n        coatings.append((s.find(sub[::-1]) + len(sub), s.find(sub[::-1]) + 1))\nif n == 0:\n    print(-1)\nelse:\n    print(n)\n    for x, y in coatings:\n        print(x, y)",
  "plan": "1. Input Reading:\n   - Read the input strings `s` and `t`.\n   - Ensure both strings are non-empty and their lengths do not exceed the given limit.\n\n2. Initialization:\n   - Initialize an empty list `substrings` to store the substrings of `t` that can be formed using `s`.\n   - Set the initial index `i` to 0, which will be used to traverse string `t`.\n\n3. Substring Search Loop:\n   - Use a while loop to iterate through `t` as long as `i` is less than the length of `t`.\n   - For each starting position `i`, find the longest substring of `t` starting from `i` that can be found in `s` or its reverse.\n   - If a valid substring is found, update the current maximum substring length and store the substring.\n   - If no valid substring is found, break the loop as it's impossible to form `t` using `s`.\n\n4. Update Index:\n   - After finding the maximum valid substring for the current position, append it to the `substrings` list.\n   - Move the index `i` forward by the length of the found substring.\n\n5. Check for Solution:\n   - If no substrings were found (`substrings` is empty), print `-1` indicating that it's impossible to form `t` using `s`.\n\n6. Determine Substring Positions:\n   - Initialize an empty list `coatings` to store the positions of the substrings found in `s`.\n   - For each substring in `substrings`, determine its position in `s` or its reverse.\n   - Store the starting and ending positions of each substring in the `coatings` list.\n\n7. Output the Result:\n   - Print the number of substrings (coatings) needed.\n   - For each substring in `coatings`, print the starting and ending positions.",
  "plan_list": "<subtask_1>\nInput Reading:\n   - Read the input strings `s` and `t`.\n   - Ensure both strings are non-empty and their lengths do not exceed the given limit.\n</subtask_1>\n<subtask_2>\nInitialization:\n   - Initialize an empty list `substrings` to store the substrings of `t` that can be formed using `s`.\n   - Set the initial index `i` to 0, which will be used to traverse string `t`.\n</subtask_2>\n<subtask_3>\nSubstring Search Loop:\n   - Use a while loop to iterate through `t` as long as `i` is less than the length of `t`.\n   - For each starting position `i`, find the longest substring of `t` starting from `i` that can be found in `s` or its reverse.\n   - If a valid substring is found, update the current maximum substring length and store the substring.\n   - If no valid substring is found, break the loop as it's impossible to form `t` using `s`.\n</subtask_3>\n<subtask_4>\nUpdate Index:\n   - After finding the maximum valid substring for the current position, append it to the `substrings` list.\n   - Move the index `i` forward by the length of the found substring.\n<subtask_4>\n<subtask_5>\nCheck for Solution:\n   - If no substrings were found (`substrings` is empty), print `-1` indicating that it's impossible to form `t` using `s`.\n</subtask_5>\n<subtask_6>\nDetermine Substring Positions:\n   - Initialize an empty list `coatings` to store the positions of the substrings found in `s`.\n   - For each substring in `substrings`, determine its position in `s` or its reverse.\n   - Store the starting and ending positions of each substring in the `coatings` list.\n</subtask_6>\n<subtask_7>\nOutput the Result:\n   - Print the number of substrings (coatings) needed.\n   - For each substring in `coatings`, print the starting and ending positions.\n</subtask_7>",
  "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": "import sys\n\nanswer = 1\nz = True\nprimes = []\nfor i in range (2, 5 * 10 ** 2):\n    v = True\n    for p in primes:\n        if i % p == 0:\n            v = False\n    if v == True:\n        primes.append(i)\nn = int(sys.stdin.readline().strip())\na = list(map(int, sys.stdin.readline().strip().split()))\nif sum(a) == n:\n    z = False\nfor i in range (0, n):\n    x = a[i]\n    a[i] = []\n    for p in primes:\n        if x % p == 0:\n            a[i].append([p, 1])\n            x = x // p\n            while x % p == 0:\n                x = x // p\n    if x != 1:\n        a[i].append([x, 1])\nneighbours = [[] for i in range (0, n)]\nfor i in range (0, n - 1):\n    line = sys.stdin.readline().strip().split()\n    neighbours[int(line[0]) - 1].append(int(line[1]) - 1)\n    neighbours[int(line[1]) - 1].append(int(line[0]) - 1)\nleaves = []\nfor i in range (0, n):\n    if len(neighbours[i]) == 1:\n        leaves.append(i)\nwhile len(leaves) > 1:\n    x = leaves.pop()\n    y = neighbours[x][0]\n    neighbours[y].remove(x)\n    if len(neighbours[y]) == 1:\n        leaves.append(y)\n    for p in a[x]:\n        for q in a[y]:\n            if p[0] == q[0]:\n                answer = max([answer, p[1] + q[1]])\n                q[1] = max([q[1],p[1]+1])\nif z == False:\n    print(0)\nelse:\n    print(answer)\n",
  "plan_2": "1. Precompute Prime Factors:\n   - Generate a list of prime numbers up to a certain limit (e.g., 500).\n   - For each vertex, decompose the number written on it into its prime factors and store these factors.\n\n2. Build the Tree:\n   - Read the input to get the number of vertices and the numbers on each vertex.\n   - Read the edges of the tree and construct the adjacency list representation of the tree.\n\n3. Identify Leaves:\n   - Identify all leaf nodes in the tree (nodes with only one connection).\n\n4. Process Leaves:\n   - Use a queue to process each leaf node. For each leaf node:\n     - Update its parent node with the GCD-related information.\n     - Remove the leaf node from the tree.\n     - If the parent node becomes a leaf, add it to the queue.\n\n5. Track Maximum Distance:\n   - Keep track of the maximum distance encountered where the GCD of the path is greater than 1.\n\n6. Edge Case Check:\n   - If all numbers on the vertices are 1, then no valid path exists (output should be 0).\n\n7. Output Result:\n   - Print the maximum distance found.",
  "plan_list_2": "<subtask_1>\nPrecompute Prime Factors:\n   - Generate a list of prime numbers up to a certain limit (e.g., 500).\n   - For each vertex, decompose the number written on it into its prime factors and store these factors.\n</subtask_1>\n<subtask_2>\nBuild the Tree:\n   - Read the input to get the number of vertices and the numbers on each vertex.\n   - Read the edges of the tree and construct the adjacency list representation of the tree.\n</subtask_2>\n<subtask_3>\nIdentify Leaves:\n   - Identify all leaf nodes in the tree (nodes with only one connection).\n</subtask_3>\n<subtask_4>\nProcess Leaves:\n   - Use a queue to process each leaf node. For each leaf node:\n     - Update its parent node with the GCD-related information.\n     - Remove the leaf node from the tree.\n     - If the parent node becomes a leaf, add it to the queue.\n</subtask_4>\n<subtask_5>\nTrack Maximum Distance:\n   - Keep track of the maximum distance encountered where the GCD of the path is greater than 1.\n</subtask_5>\n<subtask_6>\nEdge Case Check:\n   - If all numbers on the vertices are 1, then no valid path exists (output should be 0).\n</subtask_6>\n<subtask_7>\nOutput Result:\n   - Print the maximum distance found.\n<subtask_7>",
  "subtask_list": "<subtask_1>\nGiven two strings s and t, write a function that finds the longest substring of t that is either present in s or its reverse is present in s. The function should return this longest substring. If no such substring exists, return an empty string.\n\n-----Input-----\nTwo non-empty strings s and t, both consisting of small English letters with a length not exceeding 2100.\n\n-----Output-----\nThe longest substring of t that is present in s or its reverse. If no such substring exists, return an empty string.\n</subtask_1>\n<subtask_2>\nUsing the function from subproblem_1, write a function that splits string `t` into the minimum number of non-overlapping substrings, where each substring is either present in `s` or its reverse is present in `s`. If it is not possible to split `t` in this manner, return an empty list. Otherwise, return the list of substrings.\n\n-----Input-----\nTwo non-empty strings `s` and `t`, both consisting of small English letters with a length not exceeding 2100.\n\n-----Output-----\nA list of non-overlapping substrings of `t` that are either present in `s` or its reverse. If it's not possible, return an empty list.\n</subtask_2>\n<subtask_3>\nGiven the list of substrings from subproblem_2, write a function that converts this list into a list of tuples representing the starting and ending positions of each substring in the original string `s`. If the substring is used in the reversed order, the tuple should reflect this by having the starting position greater than the ending position.\n\n-----Input-----\nA string `s` and a list of substrings.\n\n\n\n-----Output-----\nA list of tuples where each tuple contains two integers representing the start and end positions of the substring in `s`. If the substring is reversed, the start position should be greater than the end position.\n</subtask_3>",
  "subtask_list_2": "<subtask_1>\nGiven a number \\( n \\), generate all prime numbers up to \\( \\sqrt{2 \times 10^5} \\). These primes will be used for factorizing the numbers on the vertices.\n\n-----Input-----\n- An integer \\( n \\) indicating the range up to which primes need to be generated.\n\n-----Output-----\n- A list of all prime numbers up to \\( \\sqrt{2 \times 10^5} \\).\n</subtask_1>\n<subtask_2>\nGiven a list of numbers on vertices of a tree and a list of prime numbers, factorize each number into its prime factors and store these factors along with their counts.\n\n-----Input-----\n- An integer \\( n \\) representing the number of vertices.\n- A list of integers \\( a \\) representing the numbers written on the vertices.\n- A list of integers \\( primes \\) representing the prime numbers up to \\( \\sqrt{2 \times 10^5} \\).\n\n-----Output-----\n- A list of lists where each sublist contains the prime factors of the corresponding vertex number and their counts.\n</subtask_2>\n<subtask_3>\nGiven the number of vertices and the edges of a tree, construct the adjacency list representation of the tree.\n\n-----Input-----\n- An integer \\( n \\) representing the number of vertices.\n- A list of \\( n-1 \\) pairs of integers representing the edges of the tree.\n\n-----Output-----\n- An adjacency list representation of the tree.\n</subtask_3>\n<subtask_4>\nGiven the adjacency list of a tree, find all leaf nodes (nodes with only one neighbor).\n\n-----Input-----\n- An integer \\( n \\) representing the number of vertices.\n- An adjacency list representation of the tree.\n\n-----Output-----\n- A list of integers representing the leaf nodes.\n</subtask_4>\n<subtask_5>\nGiven the prime factorization of each vertex and the adjacency list of the tree, find the maximum path length where the GCD of the path's numbers is greater than 1.\n\n-----Input-----\n- An integer \\( n \\) representing the number of vertices.\n- A list of lists containing the prime factors of each vertex and their counts.\n- An adjacency list representation of the tree.\n- A list of leaf nodes.\n\n-----Output-----\n- The maximum distance between two nodes such that the GCD of the numbers on the path is greater than 1, or 0 if no such path exists.\n</subtask_5>"
}
