{"trustable":false,"prependHtml":"\u003cstyle type\u003d\u0027text/css\u0027\u003e\n .input, .output {\n border: 1px solid #888888;\n }\n .output {\n margin-bottom: 1em;\n position: relative;\n top: -1px;\n }\n .output pre, .input pre {\n background-color: #EFEFEF;\n line-height: 1.25em;\n margin: 0;\n padding: 0.25em;\n }\n \u003c/style\u003e\n \u003clink rel\u003d\"stylesheet\" href\u003d\"//codeforces.org/s/96598/css/problem-statement.css\" type\u003d\"text/css\" /\u003e\u003cscript\u003e window.katexOptions \u003d { disable: true }; \u003c/script\u003e\n\u003cscript type\u003d\"text/x-mathjax-config\"\u003e\n MathJax.Hub.Config({\n tex2jax: {\n inlineMath: [[\u0027$$$\u0027,\u0027$$$\u0027], [\u0027$\u0027,\u0027$\u0027]],\n displayMath: [[\u0027$$$$$$\u0027,\u0027$$$$$$\u0027], [\u0027$$\u0027,\u0027$$\u0027]]\n }\n });\n\u003c/script\u003e\n\u003cscript type\u003d\"text/javascript\" async src\u003d\"https://mathjax.codeforces.org/MathJax.js?config\u003dTeX-AMS_HTML-full\"\u003e\u003c/script\u003e","sections":[{"title":"","value":{"format":"HTML","content":"\u003cp\u003e给定一个字符串 $$$s\u003ds_1 s_2 \\dots s_{|s|}$$$,其中 $$$|s|$$$ 是字符串 $$$s$$$ 的长度,$$$s_i$$$ 表示它的第 $$$i$$$ 个字符。\u003c/p\u003e\n\n\u003cp\u003e让我们引入几个定义:\u003c/p\u003e\n\n\u003cul\u003e\n\u003cli\u003e 字符串 $$$s$$$ 的子串 $$$s[i..j]$$$ ,是指字符串 $$$s_i s_{i+1} \\dots s_j$$$。 \u003c/li\u003e\n\u003cli\u003e 字符串 $$$s$$$ 的长度为 $$$l$$$ 的前缀, 是指字符串 $$$s[1..l]$$$。\u003c/li\u003e\n\u003cli\u003e 字符串 $$$s$$$ 的长度为 $$$l$$$ 的后缀,是指字符串 $$$s[|s|-l + 1 .. |s|]$$$ 。 \u003c/li\u003e\n\u003c/ul\u003e\n\n\u003cp\u003e你的任务是:对于字符串 $$$s$$$ 的任何前缀 (与字符串 $$$s$$$ 的一个后缀相匹配),打印它在字符串 $$$s$$$ 中作为子串出现的次数。\u003c/p\u003e"}},{"title":"输入","value":{"format":"HTML","content":"\u003cp\u003e输入一行,包含字符序列 $$$s_1 s_2 \\dots s_{|s|}$$$ $$$(1 \\leq |s| \\leq 10^5)$$$。该字符串仅包含大写英文字母。\u003c/p\u003e"}},{"title":"输出","value":{"format":"HTML","content":"\u003cp\u003e第一行打印整数 $$$k$$$ $$$(0 \\leq k \\leq |s|)$$$,表示与字符串 $$$s$$$ 的一个后缀匹配的前缀数量。 \u003c/p\u003e\n\n\u003cp\u003e接下来 $$$k$$$ 行中的第 $$$i$$$ 行,打印两个整数 $$$l_i~~c_i$$$,其中 $$$l_i$$$ 表示长度为 $$$l_i$$$ 的前缀与长度为 $$$l_i$$$ 的后缀相匹配,$$$c_i$$$ 表示该前缀在字符串 $$$s$$$ 中作为子串出现的次数。打印二元组 $$$l_i~~c_i$$$ 时,按照 $$$l_i$$$ 升序排列。\u003c/p\u003e"}},{"title":"示例 1","value":{"format":"HTML","content":"\u003ctable class\u003d\u0027vjudge_sample\u0027\u003e\n\u003cthead\u003e\n \u003ctr\u003e\n \u003cth\u003eInput\u003c/th\u003e\n \u003cth\u003eOutput\u003c/th\u003e\n \u003c/tr\u003e\n\u003c/thead\u003e\n\u003ctbody\u003e\n \u003ctr\u003e\n \u003ctd\u003e\u003cpre\u003eABACABA\n\u003c/pre\u003e\u003c/td\u003e\n \u003ctd\u003e\u003cpre\u003e3\n1 4\n3 2\n7 1\n\u003c/pre\u003e\u003c/td\u003e\n \u003c/tr\u003e\n\u003c/tbody\u003e\n\u003c/table\u003e"}},{"title":"示例 2","value":{"format":"HTML","content":"\u003ctable class\u003d\u0027vjudge_sample\u0027\u003e\n\u003cthead\u003e\n \u003ctr\u003e\n \u003cth\u003eInput\u003c/th\u003e\n \u003cth\u003eOutput\u003c/th\u003e\n \u003c/tr\u003e\n\u003c/thead\u003e\n\u003ctbody\u003e\n \u003ctr\u003e\n \u003ctd\u003e\u003cpre\u003eAAA\n\u003c/pre\u003e\u003c/td\u003e\n \u003ctd\u003e\u003cpre\u003e3\n1 3\n2 2\n3 1\n\u003c/pre\u003e\u003c/td\u003e\n \u003c/tr\u003e\n\u003c/tbody\u003e\n\u003c/table\u003e"}}]}