{"id":25,"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-20\/"},"modified":"2022-06-04T10:52:00","modified_gmt":"2022-06-04T02:52:00","slug":"2020-08-20","status":"publish","type":"post","link":"https:\/\/wordpress.tim-wcx.ltd\/index.php\/2022\/06\/04\/2020-08-20\/","title":{"rendered":"2020-08-20"},"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=2550&#038;pid=5\">http:\/\/icpc.upc.edu.cn\/problem.php?cid=2550&#038;pid=5<\/a><\/p>\n<h6><a id=\"_1\"><\/a>\u9898\u76ee\u63cf\u8ff0<\/h6>\n<p>L\u56fd\u4e00\u5171\u6709N\u5ea7\u57ce\u9547\uff0c\u5f00\u59cb\u65f6\u5b83\u4eec\u4e24\u4e24\u4e0d\u8fde\u901a\u3002L\u56fd\u8ba1\u5212\u4f9d\u6b21\u5efa\u9020N-1\u6761\u9053\u8def\uff0c\u628a\u6240\u6709\u57ce\u9547\u8fde\u901a\u8d77\u6765\u3002\u6bcf\u5efa\u5b8c\u4e00\u6761\u9053\u8def\uff0c\u4f60\u9700\u8981\u56de\u7b54\u8fd9\u6761\u9053\u8def\u6240\u5728\u8fde\u901a\u5757\u5185\u8ddd\u79bb\u6700\u8fdc\u7684\u4e24\u5ea7\u57ce\u9547\u4e4b\u95f4\u7684\u8ddd\u79bb\u3002\u4e24\u5ea7\u57ce\u9547\u4e4b\u95f4\u7684\u8ddd\u79bb\u5b9a\u4e49\u4e3a\u4ece\u4e00\u5ea7\u8d70\u5230\u53e6\u4e00\u5ea7\u6240\u9700\u8981\u7ecf\u8fc7\u7684\u6700\u5c11\u9053\u8def\u6570\u3002<\/p>\n<h6><a id=\"_3\"><\/a>\u8f93\u5165<\/h6>\n<p>\u7b2c\u4e00\u884c\u4e00\u4e2a\u6574\u6570N\uff0c\u8868\u793a\u57ce\u9547\u7684\u6570\u91cf\u3002<br \/> \u63a5\u4e0b\u6765N-1\u884c\uff0c\u6bcf\u884c\u4e24\u4e2a\u6574\u6570ai,bi\u8868\u793a\u63a5\u4e0b\u6765\u5efa\u7684\u9053\u8def\u8fde\u901a\u7684\u4e24\u5ea7\u57ce\u9547\u3002<br \/> \u4fdd\u8bc1N-1\u6761\u9053\u8def\u80fd\u591f\u4f7f\u6240\u6709\u57ce\u9547\u8fde\u901a\u3002<\/p>\n<h6><a id=\"_8\"><\/a>\u8f93\u51fa<\/h6>\n<p>\u8f93\u51faN-1\u884c\uff0c\u6bcf\u884c\u4e00\u4e2a\u6574\u6570\u8868\u793a\u5efa\u5b8c\u7b2ci\u6761\u9053\u8def\u540e\u7684\u7b54\u6848\u3002<\/p>\n<h6><a id=\"_10\"><\/a>\u6837\u4f8b\u8f93\u5165<\/h6>\n<pre><code>5\n3 5\n3 4\n1 2\n1 3\n<\/code><\/pre>\n<h6><a id=\"_18\"><\/a>\u6837\u4f8b\u8f93\u51fa<\/h6>\n<pre><code>1\n2\n1\n3\n<\/code><\/pre>\n<h6><a id=\"_25\"><\/a>\u63d0\u793a<\/h6>\n<p>\u5bf9\u4e8e20%\u7684\u6570\u636e\uff0cn\u2264300;<br \/> \u5bf9\u4e8e50%\u7684\u6570\u636e\uff0cn\u22642000;<br \/> \u5bf9\u4e8e\u53e6\u591620%\u7684\u6570\u636e\uff0c\u4fdd\u8bc1bi=i+1,ai<=i;<br \/> \u5bf9\u4e8e100%\u7684\u6570\u636e\uff0cn\u2264300000\u3002<\/p>\n<h6><a id=\"_30\"><\/a>\u89e3\u6790<\/h6>\n<p>\u53c2\u8003\u4e8e\uff1a<a href=\"https:\/\/blog.csdn.net\/qq_43857314\/article\/details\/108108130\">https:\/\/blog.csdn.net\/qq_43857314\/article\/details\/108108130<\/a><br \/> lca+st\u7b97\u6cd5\u8be6\u7ec6\u8bb2\u89e3\uff1a<br \/> <a href=\"https:\/\/www.csdn.net\/gather_27\/MtjaQg0sNjAxOTEtYmxvZwO0O0OO0O0O.html\">https:\/\/www.csdn.net\/gather_27\/MtjaQg0sNjAxOTEtYmxvZwO0O0OO0O0O.html<\/a><br \/> RMQ\u7b97\u6cd5\u5206\u6790<br \/> <a href=\"https:\/\/blog.csdn.net\/y990041769\/article\/details\/38405063\">https:\/\/blog.csdn.net\/y990041769\/article\/details\/38405063<\/a><\/p>\n<p>ST\u7b97\u6cd5\u662f\u5c06\u8df3\u7684\u6b65\u6570\u52a0\u4ee5\u4e8c\u8fdb\u5236\u4f18\u5316\u3002<br \/> LCA+ST\u500d\u589e+\u6811\u7684\u76f4\u5f84+\u5e76\u67e5\u96c6<\/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\"><cstdio><\/span><\/span>\n<span class=\"token macro property\">#<span class=\"token directive keyword\">include<\/span><span class=\"token string\"><cstring><\/span><\/span>\n<span class=\"token macro property\">#<span class=\"token directive keyword\">include<\/span><span class=\"token string\"><algorithm><\/span><\/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\">const<\/span> <span class=\"token keyword\">int<\/span> maxn<span class=\"token operator\">=<\/span><span class=\"token number\">3e5<\/span><span class=\"token operator\">+<\/span><span class=\"token number\">5<\/span><span class=\"token punctuation\">;<\/span>\n<span class=\"token keyword\">struct<\/span> node\n<span class=\"token punctuation\">{<!-- --><\/span>\n    <span class=\"token keyword\">int<\/span> to<span class=\"token punctuation\">,<\/span>nex<span class=\"token punctuation\">,<\/span>w<span class=\"token punctuation\">;<\/span>\n<span class=\"token punctuation\">}<\/span> road<span class=\"token punctuation\">[<\/span>maxn<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 keyword\">struct<\/span> nd\n<span class=\"token punctuation\">{<!-- --><\/span>\n    <span class=\"token keyword\">int<\/span> x<span class=\"token punctuation\">;<\/span>\n    <span class=\"token keyword\">int<\/span> y<span class=\"token punctuation\">;<\/span>\n<span class=\"token punctuation\">}<\/span><span class=\"token punctuation\">;<\/span>\nnd qq<span class=\"token punctuation\">[<\/span>maxn<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> n<span class=\"token punctuation\">,<\/span>q<span class=\"token punctuation\">,<\/span>cnt<span class=\"token punctuation\">;<\/span>\n<span class=\"token keyword\">int<\/span> pre<span class=\"token punctuation\">[<\/span>maxn<span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">[<\/span><span class=\"token number\">32<\/span><span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">,<\/span>head<span class=\"token punctuation\">[<\/span>maxn<span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">,<\/span>depth<span class=\"token punctuation\">[<\/span>maxn<span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">;<\/span>\n<span class=\"token keyword\">int<\/span> dis<span class=\"token punctuation\">[<\/span>maxn<span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">;<\/span>\nll fa<span class=\"token punctuation\">[<\/span>maxn<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>s<span class=\"token punctuation\">[<\/span>maxn<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>t<span class=\"token punctuation\">[<\/span>maxn<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\">void<\/span> <span class=\"token function\">add<\/span><span class=\"token punctuation\">(<\/span><span class=\"token keyword\">int<\/span> u<span class=\"token punctuation\">,<\/span><span class=\"token keyword\">int<\/span> v<span class=\"token punctuation\">,<\/span><span class=\"token keyword\">int<\/span> w<span class=\"token punctuation\">)<\/span>\n<span class=\"token punctuation\">{<!-- --><\/span>\n    road<span class=\"token punctuation\">[<\/span>cnt<span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">.<\/span>to<span class=\"token operator\">=<\/span>v<span class=\"token punctuation\">;<\/span>\n    road<span class=\"token punctuation\">[<\/span>cnt<span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">.<\/span>w<span class=\"token operator\">=<\/span>w<span class=\"token punctuation\">;<\/span>\n    road<span class=\"token punctuation\">[<\/span>cnt<span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">.<\/span>nex<span class=\"token operator\">=<\/span>head<span class=\"token punctuation\">[<\/span>u<span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">;<\/span>\n    head<span class=\"token punctuation\">[<\/span>u<span class=\"token punctuation\">]<\/span><span class=\"token operator\">=<\/span>cnt<span class=\"token operator\">++<\/span><span class=\"token punctuation\">;<\/span>\n<span class=\"token punctuation\">}<\/span>\n<span class=\"token keyword\">void<\/span> <span class=\"token function\">dfs<\/span><span class=\"token punctuation\">(<\/span><span class=\"token keyword\">int<\/span> u<span class=\"token punctuation\">,<\/span><span class=\"token keyword\">int<\/span> fa<span class=\"token punctuation\">)<\/span>\n<span class=\"token punctuation\">{<!-- --><\/span>\n    pre<span class=\"token punctuation\">[<\/span>u<span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">[<\/span><span class=\"token number\">0<\/span><span class=\"token punctuation\">]<\/span><span class=\"token operator\">=<\/span>fa<span class=\"token punctuation\">;<\/span>\n    depth<span class=\"token punctuation\">[<\/span>u<span class=\"token punctuation\">]<\/span><span class=\"token operator\">=<\/span>depth<span class=\"token punctuation\">[<\/span>fa<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> <span class=\"token punctuation\">(<\/span><span class=\"token number\">1<\/span><span class=\"token operator\"><<<\/span>i<span class=\"token punctuation\">)<\/span><span class=\"token operator\"><=<\/span>depth<span class=\"token punctuation\">[<\/span>u<span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">;<\/span> i<span class=\"token operator\">++<\/span><span class=\"token punctuation\">)<\/span> <span class=\"token comment\">\/\/\u500d\u589e<\/span>\n        pre<span class=\"token punctuation\">[<\/span>u<span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">[<\/span>i<span class=\"token punctuation\">]<\/span><span class=\"token operator\">=<\/span>pre<span class=\"token punctuation\">[<\/span>pre<span class=\"token punctuation\">[<\/span>u<span class=\"token punctuation\">]<\/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 punctuation\">]<\/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 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>head<span class=\"token punctuation\">[<\/span>u<span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">;<\/span> <span class=\"token operator\">~<\/span>i<span class=\"token punctuation\">;<\/span> i<span class=\"token operator\">=<\/span>road<span class=\"token punctuation\">[<\/span>i<span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">.<\/span>nex<span class=\"token punctuation\">)<\/span>\n    <span class=\"token punctuation\">{<!-- --><\/span>\n        <span class=\"token keyword\">int<\/span> v<span class=\"token operator\">=<\/span>road<span class=\"token punctuation\">[<\/span>i<span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">.<\/span>to<span class=\"token punctuation\">;<\/span>\n        <span class=\"token keyword\">if<\/span><span class=\"token punctuation\">(<\/span>v<span class=\"token operator\">!=<\/span>fa<span class=\"token punctuation\">)<\/span>\n        <span class=\"token punctuation\">{<!-- --><\/span>\n            dis<span class=\"token punctuation\">[<\/span>v<span class=\"token punctuation\">]<\/span><span class=\"token operator\">=<\/span>dis<span class=\"token punctuation\">[<\/span>u<span class=\"token punctuation\">]<\/span><span class=\"token operator\">+<\/span>road<span class=\"token punctuation\">[<\/span>i<span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">.<\/span>w<span class=\"token punctuation\">;<\/span>\n            <span class=\"token function\">dfs<\/span><span class=\"token punctuation\">(<\/span>v<span class=\"token punctuation\">,<\/span>u<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\">lca<\/span><span class=\"token punctuation\">(<\/span><span class=\"token keyword\">int<\/span> u<span class=\"token punctuation\">,<\/span><span class=\"token keyword\">int<\/span> v<span class=\"token punctuation\">)<\/span>\n<span class=\"token punctuation\">{<!-- --><\/span>\n    <span class=\"token keyword\">if<\/span><span class=\"token punctuation\">(<\/span>depth<span class=\"token punctuation\">[<\/span>u<span class=\"token punctuation\">]<\/span><span class=\"token operator\"><<\/span>depth<span class=\"token punctuation\">[<\/span>v<span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">)<\/span>\n    <span class=\"token punctuation\">{<!-- --><\/span>\n        <span class=\"token function\">swap<\/span><span class=\"token punctuation\">(<\/span>u<span class=\"token punctuation\">,<\/span>v<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 operator\">-<\/span><span class=\"token number\">1<\/span><span class=\"token punctuation\">,<\/span>j<span class=\"token punctuation\">;<\/span>\n    <span class=\"token keyword\">while<\/span><span class=\"token punctuation\">(<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">1<\/span><span class=\"token operator\"><<<\/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 punctuation\">)<\/span><span class=\"token operator\"><=<\/span>depth<span class=\"token punctuation\">[<\/span>u<span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">)<\/span>\n        i<span class=\"token operator\">++<\/span><span class=\"token punctuation\">;<\/span>\n    <span class=\"token keyword\">for<\/span><span class=\"token punctuation\">(<\/span>j<span class=\"token operator\">=<\/span>i<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><span class=\"token punctuation\">)<\/span>\n    <span class=\"token punctuation\">{<!-- --><\/span>\n        <span class=\"token keyword\">if<\/span><span class=\"token punctuation\">(<\/span>depth<span class=\"token punctuation\">[<\/span>u<span class=\"token punctuation\">]<\/span><span class=\"token operator\">-<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">1<\/span><span class=\"token operator\"><<<\/span>j<span class=\"token punctuation\">)<\/span><span class=\"token operator\">>=<\/span>depth<span class=\"token punctuation\">[<\/span>v<span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">)<\/span>\n        <span class=\"token punctuation\">{<!-- --><\/span>\n            u<span class=\"token operator\">=<\/span>pre<span class=\"token punctuation\">[<\/span>u<span class=\"token punctuation\">]<\/span><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 keyword\">if<\/span><span class=\"token punctuation\">(<\/span>u<span class=\"token operator\">==<\/span>v<span class=\"token punctuation\">)<\/span>\n        <span class=\"token keyword\">return<\/span> u<span class=\"token punctuation\">;<\/span>\n    <span class=\"token keyword\">for<\/span><span class=\"token punctuation\">(<\/span><span class=\"token keyword\">int<\/span> j<span class=\"token operator\">=<\/span>i<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><span class=\"token punctuation\">)<\/span>\n    <span class=\"token punctuation\">{<!-- --><\/span>\n        <span class=\"token keyword\">if<\/span><span class=\"token punctuation\">(<\/span>pre<span class=\"token punctuation\">[<\/span>u<span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">[<\/span>j<span class=\"token punctuation\">]<\/span><span class=\"token operator\">!=<\/span>pre<span class=\"token punctuation\">[<\/span>v<span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">[<\/span>j<span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">)<\/span>\n        <span class=\"token punctuation\">{<!-- --><\/span>\n            u<span class=\"token operator\">=<\/span>pre<span class=\"token punctuation\">[<\/span>u<span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">[<\/span>j<span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">;<\/span>\n            v<span class=\"token operator\">=<\/span>pre<span class=\"token punctuation\">[<\/span>v<span class=\"token punctuation\">]<\/span><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 keyword\">return<\/span> pre<span class=\"token punctuation\">[<\/span>u<span class=\"token punctuation\">]<\/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 punctuation\">}<\/span>\n<span class=\"token keyword\">int<\/span> <span class=\"token function\">findfa<\/span><span class=\"token punctuation\">(<\/span><span class=\"token keyword\">int<\/span> x<span class=\"token punctuation\">)<\/span>\n<span class=\"token punctuation\">{<!-- --><\/span>\n    <span class=\"token keyword\">if<\/span><span class=\"token punctuation\">(<\/span>fa<span class=\"token punctuation\">[<\/span>x<span class=\"token punctuation\">]<\/span><span class=\"token operator\">!=<\/span>x<span class=\"token punctuation\">)<\/span>\n        <span class=\"token keyword\">return<\/span> fa<span class=\"token punctuation\">[<\/span>x<span class=\"token punctuation\">]<\/span><span class=\"token operator\">=<\/span><span class=\"token function\">findfa<\/span><span class=\"token punctuation\">(<\/span>fa<span class=\"token punctuation\">[<\/span>x<span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>\n    <span class=\"token keyword\">else<\/span>\n        <span class=\"token keyword\">return<\/span> x<span class=\"token punctuation\">;<\/span>\n<span class=\"token punctuation\">}<\/span>\n<span class=\"token keyword\">int<\/span> <span class=\"token function\">cmp<\/span><span class=\"token punctuation\">(<\/span>ll <span class=\"token operator\">&<\/span>x<span class=\"token punctuation\">,<\/span>ll <span class=\"token operator\">&<\/span>y<span class=\"token punctuation\">,<\/span><span class=\"token keyword\">int<\/span> <span class=\"token operator\">&<\/span>z<span class=\"token punctuation\">,<\/span><span class=\"token keyword\">int<\/span> a<span class=\"token punctuation\">,<\/span><span class=\"token keyword\">int<\/span> b<span class=\"token punctuation\">)<\/span>\n<span class=\"token punctuation\">{<!-- --><\/span>\n    <span class=\"token keyword\">int<\/span> dis1<span class=\"token operator\">=<\/span>dis<span class=\"token punctuation\">[<\/span>a<span class=\"token punctuation\">]<\/span><span class=\"token operator\">+<\/span>dis<span class=\"token punctuation\">[<\/span>b<span class=\"token punctuation\">]<\/span><span class=\"token operator\">-<\/span><span class=\"token number\">2<\/span><span class=\"token operator\">*<\/span>dis<span class=\"token punctuation\">[<\/span><span class=\"token function\">lca<\/span><span class=\"token punctuation\">(<\/span>a<span class=\"token punctuation\">,<\/span>b<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">;<\/span>\n    <span class=\"token keyword\">if<\/span><span class=\"token punctuation\">(<\/span>dis1<span class=\"token operator\">><\/span>z<span class=\"token punctuation\">)<\/span>\n    <span class=\"token punctuation\">{<!-- --><\/span>\n        z<span class=\"token operator\">=<\/span>dis1<span class=\"token punctuation\">;<\/span>\n        x<span class=\"token operator\">=<\/span>a<span class=\"token punctuation\">;<\/span>\n        y<span class=\"token operator\">=<\/span>b<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\">solve<\/span><span class=\"token punctuation\">(<\/span><span class=\"token keyword\">int<\/span> x<span class=\"token punctuation\">,<\/span><span class=\"token keyword\">int<\/span> y<span class=\"token punctuation\">)<\/span>\n<span class=\"token punctuation\">{<!-- --><\/span>\n    <span class=\"token keyword\">int<\/span> fx<span class=\"token operator\">=<\/span><span class=\"token function\">findfa<\/span><span class=\"token punctuation\">(<\/span>x<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">,<\/span>fy<span class=\"token operator\">=<\/span><span class=\"token function\">findfa<\/span><span class=\"token punctuation\">(<\/span>y<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>\n    <span class=\"token keyword\">int<\/span> a<span class=\"token operator\">=<\/span>s<span class=\"token punctuation\">[<\/span>fx<span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">,<\/span>b<span class=\"token operator\">=<\/span>t<span class=\"token punctuation\">[<\/span>fx<span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">,<\/span>c<span class=\"token operator\">=<\/span>s<span class=\"token punctuation\">[<\/span>fy<span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">,<\/span>d<span class=\"token operator\">=<\/span>t<span class=\"token punctuation\">[<\/span>fy<span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">;<\/span>\n    fa<span class=\"token punctuation\">[<\/span>fx<span class=\"token punctuation\">]<\/span><span class=\"token operator\">=<\/span>fy<span class=\"token punctuation\">;<\/span>\n    <span class=\"token keyword\">int<\/span> ans<span class=\"token operator\">=<\/span><span class=\"token number\">0<\/span><span class=\"token punctuation\">;<\/span>\n    <span class=\"token function\">cmp<\/span><span class=\"token punctuation\">(<\/span>s<span class=\"token punctuation\">[<\/span>fy<span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">,<\/span>t<span class=\"token punctuation\">[<\/span>fy<span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">,<\/span>ans<span class=\"token punctuation\">,<\/span>a<span class=\"token punctuation\">,<\/span>b<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>\n    <span class=\"token function\">cmp<\/span><span class=\"token punctuation\">(<\/span>s<span class=\"token punctuation\">[<\/span>fy<span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">,<\/span>t<span class=\"token punctuation\">[<\/span>fy<span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">,<\/span>ans<span class=\"token punctuation\">,<\/span>a<span class=\"token punctuation\">,<\/span>c<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>\n    <span class=\"token function\">cmp<\/span><span class=\"token punctuation\">(<\/span>s<span class=\"token punctuation\">[<\/span>fy<span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">,<\/span>t<span class=\"token punctuation\">[<\/span>fy<span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">,<\/span>ans<span class=\"token punctuation\">,<\/span>a<span class=\"token punctuation\">,<\/span>d<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>\n    <span class=\"token function\">cmp<\/span><span class=\"token punctuation\">(<\/span>s<span class=\"token punctuation\">[<\/span>fy<span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">,<\/span>t<span class=\"token punctuation\">[<\/span>fy<span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">,<\/span>ans<span class=\"token punctuation\">,<\/span>b<span class=\"token punctuation\">,<\/span>c<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>\n    <span class=\"token function\">cmp<\/span><span class=\"token punctuation\">(<\/span>s<span class=\"token punctuation\">[<\/span>fy<span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">,<\/span>t<span class=\"token punctuation\">[<\/span>fy<span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">,<\/span>ans<span class=\"token punctuation\">,<\/span>b<span class=\"token punctuation\">,<\/span>d<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>\n    <span class=\"token function\">cmp<\/span><span class=\"token punctuation\">(<\/span>s<span class=\"token punctuation\">[<\/span>fy<span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">,<\/span>t<span class=\"token punctuation\">[<\/span>fy<span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">,<\/span>ans<span class=\"token punctuation\">,<\/span>c<span class=\"token punctuation\">,<\/span>d<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>\n    <span class=\"token keyword\">return<\/span> ans<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 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 function\">memset<\/span><span class=\"token punctuation\">(<\/span>head<span class=\"token punctuation\">,<\/span><span class=\"token operator\">-<\/span><span class=\"token number\">1<\/span><span class=\"token punctuation\">,<\/span><span class=\"token keyword\">sizeof<\/span><span class=\"token punctuation\">(<\/span>head<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>\n    <span class=\"token function\">memset<\/span><span class=\"token punctuation\">(<\/span>depth<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>depth<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">)<\/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        fa<span class=\"token punctuation\">[<\/span>i<span class=\"token punctuation\">]<\/span><span class=\"token operator\">=<\/span>s<span class=\"token punctuation\">[<\/span>i<span class=\"token punctuation\">]<\/span><span class=\"token operator\">=<\/span>t<span class=\"token punctuation\">[<\/span>i<span class=\"token punctuation\">]<\/span><span class=\"token operator\">=<\/span>i<span class=\"token punctuation\">;<\/span>\n    cnt<span class=\"token operator\">=<\/span><span class=\"token number\">0<\/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    <span class=\"token punctuation\">{<!-- --><\/span>\n        <span class=\"token keyword\">int<\/span> u<span class=\"token punctuation\">,<\/span>v<span class=\"token punctuation\">,<\/span>w<span class=\"token punctuation\">;<\/span>\n        <span class=\"token function\">scanf<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">\"%d %d\"<\/span><span class=\"token punctuation\">,<\/span><span class=\"token operator\">&<\/span>u<span class=\"token punctuation\">,<\/span><span class=\"token operator\">&<\/span>v<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>\n        w<span class=\"token operator\">=<\/span><span class=\"token number\">1<\/span><span class=\"token punctuation\">;<\/span>\n        qq<span class=\"token punctuation\">[<\/span>i<span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">.<\/span>x<span class=\"token operator\">=<\/span>u<span class=\"token punctuation\">;<\/span>\n        qq<span class=\"token punctuation\">[<\/span>i<span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">.<\/span>y<span class=\"token operator\">=<\/span>v<span class=\"token punctuation\">;<\/span>\n        <span class=\"token function\">add<\/span><span class=\"token punctuation\">(<\/span>u<span class=\"token punctuation\">,<\/span>v<span class=\"token punctuation\">,<\/span>w<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>\n        <span class=\"token function\">add<\/span><span class=\"token punctuation\">(<\/span>v<span class=\"token punctuation\">,<\/span>u<span class=\"token punctuation\">,<\/span>w<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>\n    <span class=\"token punctuation\">}<\/span>\n    dis<span class=\"token punctuation\">[<\/span><span class=\"token number\">1<\/span><span class=\"token punctuation\">]<\/span><span class=\"token operator\">=<\/span><span class=\"token number\">0<\/span><span class=\"token punctuation\">;<\/span>\n    <span class=\"token function\">dfs<\/span><span class=\"token punctuation\">(<\/span><span class=\"token number\">1<\/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\">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        <span class=\"token function\">printf<\/span><span class=\"token punctuation\">(<\/span><span class=\"token string\">\"%dn\"<\/span><span class=\"token punctuation\">,<\/span><span class=\"token function\">solve<\/span><span class=\"token punctuation\">(<\/span>qq<span class=\"token punctuation\">[<\/span>i<span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">.<\/span>x<span class=\"token punctuation\">,<\/span>qq<span class=\"token punctuation\">[<\/span>i<span class=\"token punctuation\">]<\/span><span class=\"token punctuation\">.<\/span>y<span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">)<\/span><span class=\"token punctuation\">;<\/span>\n    <span class=\"token punctuation\">}<\/span>\n<span class=\"token punctuation\">}<\/span>\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-25","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\/25","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=25"}],"version-history":[{"count":0,"href":"https:\/\/wordpress.tim-wcx.ltd\/index.php\/wp-json\/wp\/v2\/posts\/25\/revisions"}],"wp:attachment":[{"href":"https:\/\/wordpress.tim-wcx.ltd\/index.php\/wp-json\/wp\/v2\/media?parent=25"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/wordpress.tim-wcx.ltd\/index.php\/wp-json\/wp\/v2\/categories?post=25"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/wordpress.tim-wcx.ltd\/index.php\/wp-json\/wp\/v2\/tags?post=25"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}