{"id":46,"date":"2022-06-04T10:52:00","date_gmt":"2022-06-04T02:52:00","guid":{"rendered":"http:\/\/ubuntu.tim-wcx.ltd\/wordpress\/index.php\/2022\/06\/04\/2020-08-01\/"},"modified":"2022-06-04T10:52:00","modified_gmt":"2022-06-04T02:52:00","slug":"2020-08-01","status":"publish","type":"post","link":"https:\/\/wordpress.tim-wcx.ltd\/index.php\/2022\/06\/04\/2020-08-01\/","title":{"rendered":"2020-08-01"},"content":{"rendered":"<p><svg  style=\"display: none;\">\n                        <path stroke-linecap=\"round\" d=\"M5,0 0,2.5 5,5z\" id=\"raphael-marker-block\" style=\"-webkit-tap-highlight-color: rgba(0, 0, 0, 0);\"><\/path>\n                    <\/svg><\/p>\n<p><a href=\"http:\/\/icpc.upc.edu.cn\/problem.php?cid=1459&#038;pid=4\">http:\/\/icpc.upc.edu.cn\/problem.php?cid=1459&#038;pid=4<\/a><\/p>\n<h5><a id=\"_1\"><\/a>\u9898\u76ee\u63cf\u8ff0<\/h5>\n<p>Three friends like to play the following game. The first friend chooses a string S. Then the second friend constructs a new string T that consists of two copies of the string S. finally, the third friend inserts one letter at the beginning, the end or somewhere inside the string T, thereby creating a string U.<br \/> You are given the string U and your task is to reconstruct the original string S.<\/p>\n<h5><a id=\"_4\"><\/a>\u8f93\u5165<\/h5>\n<p>The first line of the input contains N\uff082 \u2264 N \u2264 2000001\uff09, the length of the final string U. The string U itself is given on the second line. It consists of N uppercase English letters (A, B, C, . . . , Z).<\/p>\n<h5><a id=\"_6\"><\/a>\u8f93\u51fa<\/h5>\n<p>Your program should print the original string S. However, there are two exceptions:<br \/> 1.If the final string U could not have been created using the above procedure, you should print NOT POSSIBLE.<br \/> 2.If the original string S is not unique, you should print NOT UNIQUE.<\/p>\n<h5><a id=\"_10\"><\/a>\u6837\u4f8b\u8f93\u5165<\/h5>\n<pre><code>7\nABXCABC\n<\/code><\/pre>\n<h5><a id=\"_15\"><\/a>\u6837\u4f8b\u8f93\u51fa<\/h5>\n<pre><code>ABC\n<\/code><\/pre>\n<h5><a id=\"_19\"><\/a>\u89e3\u6790<\/h5>\n<p>\u5b57\u7b26\u4e32\u54c8\u5e0c\u7684\u5e94\u7528\uff0c\u6bd4\u8f83\u53bb\u9664\u4e00\u4e2a\u5b57\u6bcd\u540e\u524d\u534a\u90e8\u5206\u7684\u54c8\u5e0c\u503c\u548c\u540e\u534a\u90e8\u5206\u54c8\u5e0c\u503c\u662f\u5426\u76f8\u540c<\/p>\n<pre><code class=\"prism language-cpp\"><span class=\"token macro property\">#<span class=\"token directive keyword\">pragma<\/span> GCC optimize(1)<\/span>\n<span class=\"token macro property\">#<span class=\"token directive keyword\">pragma<\/span> GCC optimize(2)<\/span>\n<span class=\"token macro property\">#<span class=\"token directive keyword\">pragma<\/span> GCC optimize(3,\"Ofast\",\"inline\")<\/span>\n<span class=\"token macro property\">#<span class=\"token directive keyword\">include<\/span> <span class=\"token string\"><bits\/stdc++.h><\/span><\/span>\n<span class=\"token keyword\">using<\/span> <span class=\"token keyword\">namespace<\/span> std<span class=\"token punctuation\">;<\/span>\n<span class=\"token keyword\">typedef<\/span> <span class=\"token keyword\">long<\/span> <span class=\"token keyword\">long<\/span> ll<span class=\"token punctuation\">;<\/span>\n<span class=\"token keyword\">typedef<\/span> <span class=\"token keyword\">unsigned<\/span> <span class=\"token keyword\">long<\/span> <span class=\"token keyword\">long<\/span> ull<span class=\"token punctuation\">;<\/span>\n<span class=\"token keyword\">const<\/span> <span class=\"token keyword\">int<\/span> N<span class=\"token operator\">=<\/span><span class=\"token number\">2e6<\/span><span class=\"token operator\">+<\/span><span class=\"token number\">500<\/span><span class=\"token punctuation\">;<\/span>\n<span class=\"token keyword\">char<\/span> a<span class=\"token punctuation\">[<\/span>N<span class=\"token punctuation\">]<\/span><span class=\"token operator\">=<\/span><span class=\"token string\">\"\"<\/span><span class=\"token punctuation\">;<\/span>\n<span class=\"token keyword\">int<\/span> base<span class=\"token operator\">=<\/span><span class=\"token number\">131<\/span><span class=\"token punctuation\">;<\/span>\null p<span class=\"token punctuation\">[<\/span>N<span class=\"token punctuation\">]<\/span><span class=\"token operator\">=<\/span><span class=\"token punctuation\">{<!-- --><\/span><span class=\"token number\">0<\/span><span class=\"token punctuation\">}<\/span><span class=\"token punctuation\">;<\/span>\null h<span class=\"token punctuation\">[<\/span>N<span class=\"token punctuation\">]<\/span><span class=\"token operator\">=<\/span><span class=\"token punctuation\">{<!-- --><\/span><span class=\"token number\">0<\/span><span class=\"token punctuation\">}<\/span><span class=\"token punctuation\">;<\/span>\null <span class=\"token function\">get<\/span><span class=\"token punctuation\">(<\/span>ull l<span class=\"token punctuation\">,<\/span>ull r<span class=\"token punctuation\">)<\/span>\n<span class=\"token punctuation\">{<!-- --><\/span>\n    <span class=\"token keyword\">return<\/span> h<span class=\"token punctuation\">[<\/span>r<span class=\"token punctuation\">]<\/span><span class=\"token operator\">-<\/span>h<span class=\"token punctuation\">[<\/span>l<span class=\"token operator\">-<\/span><span class=\"token number\">1<\/span><span class=\"token punctuation\">]<\/span><span class=\"token operator\">*<\/span>p<span class=\"token punctuation\">[<\/span>r<span class=\"token operator\">-<\/span>l<span class=\"token operator\">+<\/span><span class=\"token number\">1<\/span><span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">;<\/span>\n<span class=\"token punctuation\">}<\/span>\n<span class=\"token keyword\">int<\/span> <span class=\"token function\">main<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span>\n<span class=\"token punctuation\">{<!-- --><\/span>\n    <span class=\"token keyword\">int<\/span> n<span class=\"token punctuation\">;<\/span>\n    <span class=\"token function\">scanf<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">\"%d\"<\/span><span class=\"token punctuation\">,<\/span><span class=\"token operator\">&<\/span>n<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>\n    <span class=\"token keyword\">if<\/span><span class=\"token punctuation\">(<\/span>n<span class=\"token operator\">%<\/span><span class=\"token number\">2<\/span><span class=\"token operator\">==<\/span><span class=\"token number\">0<\/span><span class=\"token punctuation\">)<\/span>\n    <span class=\"token punctuation\">{<!-- --><\/span>\n        <span class=\"token function\">printf<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">\"NOT POSSIBLEn\"<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>\n        <span class=\"token keyword\">return<\/span> <span class=\"token number\">0<\/span><span class=\"token punctuation\">;<\/span>\n    <span class=\"token punctuation\">}<\/span>\n    <span class=\"token function\">scanf<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">\"%s\"<\/span><span class=\"token punctuation\">,<\/span>a<span class=\"token operator\">+<\/span><span class=\"token number\">1<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>\n    p<span class=\"token punctuation\">[<\/span><span class=\"token number\">0<\/span><span class=\"token punctuation\">]<\/span><span class=\"token operator\">=<\/span><span class=\"token number\">1<\/span><span class=\"token punctuation\">;<\/span>\n    <span class=\"token keyword\">for<\/span><span class=\"token punctuation\">(<\/span><span class=\"token keyword\">int<\/span> i<span class=\"token operator\">=<\/span><span class=\"token number\">1<\/span><span class=\"token punctuation\">;<\/span>i<span class=\"token operator\"><=<\/span>n<span class=\"token punctuation\">;<\/span>i<span class=\"token operator\">++<\/span><span class=\"token punctuation\">)<\/span>\n        p<span class=\"token punctuation\">[<\/span>i<span class=\"token punctuation\">]<\/span><span class=\"token operator\">=<\/span>p<span class=\"token punctuation\">[<\/span>i<span class=\"token operator\">-<\/span><span class=\"token number\">1<\/span><span class=\"token punctuation\">]<\/span><span class=\"token operator\">*<\/span>base<span class=\"token punctuation\">;<\/span>\n    <span class=\"token keyword\">for<\/span><span class=\"token punctuation\">(<\/span><span class=\"token keyword\">int<\/span> i<span class=\"token operator\">=<\/span><span class=\"token number\">1<\/span><span class=\"token punctuation\">;<\/span>i<span class=\"token operator\"><=<\/span>n<span class=\"token punctuation\">;<\/span>i<span class=\"token operator\">++<\/span><span class=\"token punctuation\">)<\/span>\n        h<span class=\"token punctuation\">[<\/span>i<span class=\"token punctuation\">]<\/span><span class=\"token operator\">=<\/span>h<span class=\"token punctuation\">[<\/span>i<span class=\"token operator\">-<\/span><span class=\"token number\">1<\/span><span class=\"token punctuation\">]<\/span><span class=\"token operator\">*<\/span>base<span class=\"token operator\">+<\/span>a<span class=\"token punctuation\">[<\/span>i<span class=\"token punctuation\">]<\/span><span class=\"token operator\">-<\/span><span class=\"token string\">'A'<\/span><span class=\"token punctuation\">;<\/span>\n    ull flag<span class=\"token operator\">=<\/span><span class=\"token number\">0<\/span><span class=\"token punctuation\">,<\/span>ans<span class=\"token punctuation\">,<\/span>pos<span class=\"token punctuation\">;<\/span>    <span class=\"token comment\">\/\/\/\u6ce8\u610f\u7528ull\uff0cans\u6570\u636e\u6bd4\u8f83\u5927<\/span>\n    <span class=\"token keyword\">for<\/span><span class=\"token punctuation\">(<\/span><span class=\"token keyword\">int<\/span> i<span class=\"token operator\">=<\/span><span class=\"token number\">1<\/span><span class=\"token punctuation\">;<\/span>i<span class=\"token operator\"><=<\/span>n<span class=\"token punctuation\">;<\/span>i<span class=\"token operator\">++<\/span><span class=\"token punctuation\">)<\/span>\n    <span class=\"token punctuation\">{<!-- --><\/span>\n        ull s1<span class=\"token punctuation\">,<\/span>s2<span class=\"token punctuation\">;<\/span>\n        <span class=\"token keyword\">if<\/span><span class=\"token punctuation\">(<\/span>i<span class=\"token operator\"><=<\/span>n<span class=\"token operator\">\/<\/span><span class=\"token number\">2<\/span><span class=\"token punctuation\">)<\/span>\n        <span class=\"token punctuation\">{<!-- --><\/span>\n            s1<span class=\"token operator\">=<\/span>h<span class=\"token punctuation\">[<\/span>i<span class=\"token operator\">-<\/span><span class=\"token number\">1<\/span><span class=\"token punctuation\">]<\/span><span class=\"token operator\">*<\/span>p<span class=\"token punctuation\">[<\/span>n<span class=\"token operator\">\/<\/span><span class=\"token number\">2<\/span><span class=\"token operator\">-<\/span>i<span class=\"token operator\">+<\/span><span class=\"token number\">1<\/span><span class=\"token punctuation\">]<\/span><span class=\"token operator\">+<\/span><span class=\"token function\">get<\/span><span class=\"token punctuation\">(<\/span>i<span class=\"token operator\">+<\/span><span class=\"token number\">1<\/span><span class=\"token punctuation\">,<\/span>n<span class=\"token operator\">\/<\/span><span class=\"token number\">2<\/span><span class=\"token operator\">+<\/span><span class=\"token number\">1<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>\n        <span class=\"token punctuation\">}<\/span>\n        <span class=\"token keyword\">else<\/span>\n        <span class=\"token punctuation\">{<!-- --><\/span>\n            s1<span class=\"token operator\">=<\/span>h<span class=\"token punctuation\">[<\/span>n<span class=\"token operator\">\/<\/span><span class=\"token number\">2<\/span><span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">;<\/span>\n        <span class=\"token punctuation\">}<\/span>\n        <span class=\"token keyword\">if<\/span><span class=\"token punctuation\">(<\/span>i<span class=\"token operator\"><=<\/span>n<span class=\"token operator\">\/<\/span><span class=\"token number\">2<\/span><span class=\"token operator\">+<\/span><span class=\"token number\">1<\/span><span class=\"token punctuation\">)<\/span>\n        <span class=\"token punctuation\">{<!-- --><\/span>\n            s2<span class=\"token operator\">=<\/span><span class=\"token function\">get<\/span><span class=\"token punctuation\">(<\/span>n<span class=\"token operator\">-<\/span>n<span class=\"token operator\">\/<\/span><span class=\"token number\">2<\/span><span class=\"token operator\">+<\/span><span class=\"token number\">1<\/span><span class=\"token punctuation\">,<\/span>n<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>\n        <span class=\"token punctuation\">}<\/span>\n        <span class=\"token keyword\">else<\/span>\n        <span class=\"token punctuation\">{<!-- --><\/span>\n            s2<span class=\"token operator\">=<\/span><span class=\"token function\">get<\/span><span class=\"token punctuation\">(<\/span>n<span class=\"token operator\">\/<\/span><span class=\"token number\">2<\/span><span class=\"token operator\">+<\/span><span class=\"token number\">1<\/span><span class=\"token punctuation\">,<\/span>i<span class=\"token operator\">-<\/span><span class=\"token number\">1<\/span><span class=\"token punctuation\">)<\/span><span class=\"token operator\">*<\/span>p<span class=\"token punctuation\">[<\/span>n<span class=\"token operator\">-<\/span>i<span class=\"token punctuation\">]<\/span><span class=\"token operator\">+<\/span><span class=\"token function\">get<\/span><span class=\"token punctuation\">(<\/span>i<span class=\"token operator\">+<\/span><span class=\"token number\">1<\/span><span class=\"token punctuation\">,<\/span>n<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>\n        <span class=\"token punctuation\">}<\/span>\n        <span class=\"token keyword\">if<\/span><span class=\"token punctuation\">(<\/span>s1<span class=\"token operator\">==<\/span>s2<span class=\"token punctuation\">)<\/span>\n        <span class=\"token punctuation\">{<!-- --><\/span>\n            <span class=\"token keyword\">if<\/span><span class=\"token punctuation\">(<\/span>flag<span class=\"token operator\">&&<\/span>ans<span class=\"token operator\">!=<\/span>s1<span class=\"token punctuation\">)<\/span>\n            <span class=\"token punctuation\">{<!-- --><\/span>\n                <span class=\"token function\">printf<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">\"NOT UNIQUEn\"<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>\n                <span class=\"token keyword\">return<\/span> <span class=\"token number\">0<\/span><span class=\"token punctuation\">;<\/span>\n            <span class=\"token punctuation\">}<\/span>\n            ans<span class=\"token operator\">=<\/span>s1<span class=\"token punctuation\">;<\/span>\n            pos<span class=\"token operator\">=<\/span>i<span class=\"token punctuation\">;<\/span>\n            flag<span class=\"token operator\">=<\/span><span class=\"token number\">1<\/span><span class=\"token punctuation\">;<\/span>\n        <span class=\"token punctuation\">}<\/span>\n    <span class=\"token punctuation\">}<\/span>\n    <span class=\"token keyword\">if<\/span><span class=\"token punctuation\">(<\/span>flag<span class=\"token punctuation\">)<\/span>\n    <span class=\"token punctuation\">{<!-- --><\/span>\n        <span class=\"token keyword\">for<\/span><span class=\"token punctuation\">(<\/span><span class=\"token keyword\">int<\/span> i<span class=\"token operator\">=<\/span><span class=\"token number\">1<\/span><span class=\"token punctuation\">,<\/span>j<span class=\"token operator\">=<\/span><span class=\"token number\">0<\/span><span class=\"token punctuation\">;<\/span>j<span class=\"token operator\"><<\/span>n<span class=\"token operator\">\/<\/span><span class=\"token number\">2<\/span><span class=\"token punctuation\">;<\/span>i<span class=\"token operator\">++<\/span><span class=\"token punctuation\">)<\/span>\n        <span class=\"token punctuation\">{<!-- --><\/span>\n            <span class=\"token keyword\">if<\/span><span class=\"token punctuation\">(<\/span>i<span class=\"token operator\">==<\/span>pos<span class=\"token punctuation\">)<\/span>\n                <span class=\"token keyword\">continue<\/span><span class=\"token punctuation\">;<\/span>\n            <span class=\"token keyword\">else<\/span>\n                <span class=\"token function\">printf<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">\"%c\"<\/span><span class=\"token punctuation\">,<\/span>a<span class=\"token punctuation\">[<\/span>i<span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">,<\/span>j<span class=\"token operator\">++<\/span><span class=\"token punctuation\">;<\/span>\n        <span class=\"token punctuation\">}<\/span>\n        <span class=\"token function\">printf<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">\"n\"<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>\n    <span class=\"token punctuation\">}<\/span>\n    <span class=\"token keyword\">else<\/span>\n    <span class=\"token punctuation\">{<!-- --><\/span>\n        <span class=\"token function\">printf<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">\"NOT POSSIBLEn\"<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>\n    <span class=\"token punctuation\">}<\/span>\n<span class=\"token punctuation\">}<\/span>\n\n\n<\/code><\/pre>\n<p><a href=\"http:\/\/icpc.upc.edu.cn\/problem.php?cid=1459&#038;pid=10\">http:\/\/icpc.upc.edu.cn\/problem.php?cid=1459&#038;pid=10<\/a><\/p>\n<h5><a id=\"_107\"><\/a>\u9898\u76ee\u63cf\u8ff0<\/h5>\n<p>\u4e00\u5757\u82b1\u5e03\u6761\uff0c\u91cc\u9762\u6709\u4e9b\u56fe\u6848\uff0c\u53e6\u6709\u4e00\u5757\u76f4\u63a5\u53ef\u7528\u7684\u5c0f\u9970\u6761\uff0c\u91cc\u9762\u4e5f\u6709\u4e00\u4e9b\u56fe\u6848\u3002\u5bf9\u4e8e\u7ed9\u5b9a\u7684\u82b1\u5e03\u6761\u548c\u5c0f\u9970\u6761\uff0c\u8ba1\u7b97\u4e00\u4e0b\u80fd\u4ece\u82b1\u5e03\u6761\u4e2d\u5c3d\u53ef\u80fd\u526a\u51fa\u51e0\u5757\u5c0f\u9970\u6761\u6765\u5462\uff1f<\/p>\n<h5><a id=\"_109\"><\/a>\u8f93\u5165<\/h5>\n<p>\u8f93\u5165\u4e2d\u542b\u6709\u4e00\u4e9b\u6570\u636e\uff0c\u5206\u522b\u662f\u6210\u5bf9\u51fa\u73b0\u7684\u82b1\u5e03\u6761\u548c\u5c0f\u9970\u6761\uff0c\u5176\u5e03\u6761\u90fd\u662f\u7528\u53ef\u89c1ASCII\u5b57\u7b26\u8868\u793a\u7684\uff0c\u53ef\u89c1\u7684ASCII\u5b57\u7b26\u6709\u591a\u5c11\u4e2a\uff0c\u5e03\u6761\u7684\u82b1\u7eb9\u4e5f\u6709\u591a\u5c11\u79cd\u82b1\u6837\u3002\u82b1\u7eb9\u6761\u548c\u5c0f\u9970\u6761\u4e0d\u4f1a\u8d85\u8fc71000\u4e2a\u5b57\u7b26\u957f\u3002\u5982\u679c\u9047\u89c1#\u5b57\u7b26\uff0c\u5219\u4e0d\u518d\u8fdb\u884c\u5de5\u4f5c\u3002<\/p>\n<h5><a id=\"_111\"><\/a>\u8f93\u51fa<\/h5>\n<p>\u8f93\u51fa\u80fd\u4ece\u82b1\u7eb9\u5e03\u4e2d\u526a\u51fa\u7684\u6700\u591a\u5c0f\u9970\u6761\u4e2a\u6570\uff0c\u5982\u679c\u4e00\u5757\u90fd\u6ca1\u6709\uff0c\u90a3\u5c31\u8001\u8001\u5b9e\u5b9e\u8f93\u51fa0\uff0c\u6bcf\u4e2a\u7ed3\u679c\u4e4b\u95f4\u5e94\u6362\u884c\u3002<\/p>\n<h5><a id=\"_113\"><\/a>\u6837\u4f8b\u8f93\u5165<\/h5>\n<pre><code>abcde a3\naaaaaa  aa\n#\n<\/code><\/pre>\n<h5><a id=\"_119\"><\/a>\u6837\u4f8b\u8f93\u51fa<\/h5>\n<pre><code>0\n3\n<\/code><\/pre>\n<h5><a id=\"_124\"><\/a>\u89e3\u6790<\/h5>\n<p>kmp\u6a21\u677f\u9898\u76ee\uff0c\u5339\u914d\u76f8\u540c\u7684\u5b57\u7b26\u4e32<\/p>\n<pre><code class=\"prism language-cpp\"><span class=\"token macro property\">#<span class=\"token directive keyword\">include<\/span><span class=\"token string\"><bits\/stdc++.h><\/span><\/span>\n<span class=\"token keyword\">using<\/span> <span class=\"token keyword\">namespace<\/span> std<span class=\"token punctuation\">;<\/span>\n<span class=\"token keyword\">char<\/span> a<span class=\"token punctuation\">[<\/span><span class=\"token number\">2005<\/span><span class=\"token punctuation\">]<\/span><span class=\"token operator\">=<\/span><span class=\"token punctuation\">{<!-- --><\/span><span class=\"token number\">0<\/span><span class=\"token punctuation\">}<\/span><span class=\"token punctuation\">;<\/span>\n<span class=\"token keyword\">char<\/span> str<span class=\"token punctuation\">[<\/span><span class=\"token number\">2005<\/span><span class=\"token punctuation\">]<\/span><span class=\"token operator\">=<\/span><span class=\"token punctuation\">{<!-- --><\/span><span class=\"token number\">0<\/span><span class=\"token punctuation\">}<\/span><span class=\"token punctuation\">;<\/span>\n<span class=\"token keyword\">int<\/span> Next<span class=\"token punctuation\">[<\/span><span class=\"token number\">2005<\/span><span class=\"token punctuation\">]<\/span><span class=\"token operator\">=<\/span><span class=\"token punctuation\">{<!-- --><\/span><span class=\"token number\">0<\/span><span class=\"token punctuation\">}<\/span><span class=\"token punctuation\">;<\/span>\n<span class=\"token keyword\">int<\/span> <span class=\"token function\">getNext<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span>\n<span class=\"token punctuation\">{<!-- --><\/span>\n    <span class=\"token keyword\">int<\/span> i<span class=\"token operator\">=<\/span><span class=\"token number\">0<\/span><span class=\"token punctuation\">,<\/span>j<span class=\"token operator\">=<\/span><span class=\"token operator\">-<\/span><span class=\"token number\">1<\/span><span class=\"token punctuation\">;<\/span>\n    Next<span class=\"token punctuation\">[<\/span><span class=\"token number\">0<\/span><span class=\"token punctuation\">]<\/span><span class=\"token operator\">=<\/span><span class=\"token operator\">-<\/span><span class=\"token number\">1<\/span><span class=\"token punctuation\">;<\/span>\n    <span class=\"token keyword\">while<\/span><span class=\"token punctuation\">(<\/span>a<span class=\"token punctuation\">[<\/span>i<span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">)<\/span>\n    <span class=\"token punctuation\">{<!-- --><\/span>\n        <span class=\"token keyword\">if<\/span><span class=\"token punctuation\">(<\/span>j<span class=\"token operator\">==<\/span><span class=\"token operator\">-<\/span><span class=\"token number\">1<\/span><span class=\"token operator\">||<\/span>a<span class=\"token punctuation\">[<\/span>i<span class=\"token punctuation\">]<\/span><span class=\"token operator\">==<\/span>a<span class=\"token punctuation\">[<\/span>j<span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">)<\/span>\n        <span class=\"token punctuation\">{<!-- --><\/span>\n            i<span class=\"token operator\">++<\/span><span class=\"token punctuation\">;<\/span>\n            j<span class=\"token operator\">++<\/span><span class=\"token punctuation\">;<\/span>\n            Next<span class=\"token punctuation\">[<\/span>i<span class=\"token punctuation\">]<\/span><span class=\"token operator\">=<\/span>j<span class=\"token punctuation\">;<\/span>\n        <span class=\"token punctuation\">}<\/span>\n        <span class=\"token keyword\">else<\/span>\n        <span class=\"token punctuation\">{<!-- --><\/span>\n            j<span class=\"token operator\">=<\/span>Next<span class=\"token punctuation\">[<\/span>j<span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">;<\/span>\n        <span class=\"token punctuation\">}<\/span>\n    <span class=\"token punctuation\">}<\/span>\n<span class=\"token punctuation\">}<\/span>\n<span class=\"token keyword\">int<\/span> <span class=\"token function\">main<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span>\n<span class=\"token punctuation\">{<!-- --><\/span>\n    <span class=\"token keyword\">while<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">1<\/span><span class=\"token punctuation\">)<\/span>\n    <span class=\"token punctuation\">{<!-- --><\/span>\n        <span class=\"token function\">scanf<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">\"%s\"<\/span><span class=\"token punctuation\">,<\/span>str<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>\n        <span class=\"token keyword\">if<\/span><span class=\"token punctuation\">(<\/span>str<span class=\"token punctuation\">[<\/span><span class=\"token number\">0<\/span><span class=\"token punctuation\">]<\/span><span class=\"token operator\">==<\/span><span class=\"token string\">'#'<\/span><span class=\"token punctuation\">)<\/span>\n            <span class=\"token keyword\">break<\/span><span class=\"token punctuation\">;<\/span>\n        <span class=\"token function\">memset<\/span><span class=\"token punctuation\">(<\/span>Next<span class=\"token punctuation\">,<\/span><span class=\"token number\">0<\/span><span class=\"token punctuation\">,<\/span><span class=\"token keyword\">sizeof<\/span><span class=\"token punctuation\">(<\/span>Next<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>\n        <span class=\"token function\">scanf<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">\"%s\"<\/span><span class=\"token punctuation\">,<\/span>a<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>\n        <span class=\"token function\">getNext<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>\n        <span class=\"token keyword\">int<\/span> lena<span class=\"token operator\">=<\/span><span class=\"token function\">strlen<\/span><span class=\"token punctuation\">(<\/span>a<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">,<\/span>lens<span class=\"token operator\">=<\/span><span class=\"token function\">strlen<\/span><span class=\"token punctuation\">(<\/span>str<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>\n        <span class=\"token keyword\">int<\/span> j<span class=\"token operator\">=<\/span><span class=\"token number\">0<\/span><span class=\"token punctuation\">,<\/span>sum<span class=\"token operator\">=<\/span><span class=\"token number\">0<\/span><span class=\"token punctuation\">,<\/span>i<span class=\"token operator\">=<\/span><span class=\"token number\">0<\/span><span class=\"token punctuation\">;<\/span>\n        <span class=\"token keyword\">while<\/span><span class=\"token punctuation\">(<\/span>i<span class=\"token operator\"><=<\/span>lens<span class=\"token punctuation\">)<\/span>\n        <span class=\"token punctuation\">{<!-- --><\/span>\n            <span class=\"token keyword\">if<\/span><span class=\"token punctuation\">(<\/span>j<span class=\"token operator\">==<\/span><span class=\"token operator\">-<\/span><span class=\"token number\">1<\/span><span class=\"token operator\">||<\/span>str<span class=\"token punctuation\">[<\/span>i<span class=\"token punctuation\">]<\/span><span class=\"token operator\">==<\/span>a<span class=\"token punctuation\">[<\/span>j<span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">)<\/span>\n            <span class=\"token punctuation\">{<!-- --><\/span>\n                i<span class=\"token operator\">++<\/span><span class=\"token punctuation\">;<\/span>\n                j<span class=\"token operator\">++<\/span><span class=\"token punctuation\">;<\/span>\n            <span class=\"token punctuation\">}<\/span>\n            <span class=\"token keyword\">else<\/span>\n            <span class=\"token punctuation\">{<!-- --><\/span>\n                j<span class=\"token operator\">=<\/span>Next<span class=\"token punctuation\">[<\/span>j<span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">;<\/span>\n            <span class=\"token punctuation\">}<\/span>\n            <span class=\"token keyword\">if<\/span><span class=\"token punctuation\">(<\/span>j<span class=\"token operator\">==<\/span>lena<span class=\"token punctuation\">)<\/span>\n            <span class=\"token punctuation\">{<!-- --><\/span>\n                sum<span class=\"token operator\">++<\/span><span class=\"token punctuation\">;<\/span>\n                j<span class=\"token operator\">=<\/span><span class=\"token number\">0<\/span><span class=\"token punctuation\">;<\/span>\n            <span class=\"token punctuation\">}<\/span>\n        <span class=\"token punctuation\">}<\/span>\n        <span class=\"token function\">printf<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">\"%dn\"<\/span><span class=\"token punctuation\">,<\/span>sum<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>\n    <span class=\"token punctuation\">}<\/span>\n<span class=\"token punctuation\">}<\/span>\n\n<\/code><\/pre>\n","protected":false},"excerpt":{"rendered":"<p>http:\/\/icpc.upc.edu.cn\/pr&hellip;<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[1],"tags":[],"class_list":["post-46","post","type-post","status-publish","format-standard","hentry","category-uncategorized"],"_links":{"self":[{"href":"https:\/\/wordpress.tim-wcx.ltd\/index.php\/wp-json\/wp\/v2\/posts\/46","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/wordpress.tim-wcx.ltd\/index.php\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/wordpress.tim-wcx.ltd\/index.php\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/wordpress.tim-wcx.ltd\/index.php\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/wordpress.tim-wcx.ltd\/index.php\/wp-json\/wp\/v2\/comments?post=46"}],"version-history":[{"count":0,"href":"https:\/\/wordpress.tim-wcx.ltd\/index.php\/wp-json\/wp\/v2\/posts\/46\/revisions"}],"wp:attachment":[{"href":"https:\/\/wordpress.tim-wcx.ltd\/index.php\/wp-json\/wp\/v2\/media?parent=46"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/wordpress.tim-wcx.ltd\/index.php\/wp-json\/wp\/v2\/categories?post=46"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/wordpress.tim-wcx.ltd\/index.php\/wp-json\/wp\/v2\/tags?post=46"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}