{"id":166,"date":"2012-04-06T00:44:37","date_gmt":"2012-04-05T16:44:37","guid":{"rendered":"http:\/\/www.shuizilong.com\/house\/?p=166"},"modified":"2012-04-06T13:57:20","modified_gmt":"2012-04-06T05:57:20","slug":"sgu-507-treediff","status":"publish","type":"post","link":"https:\/\/www.shuizilong.com\/house\/archives\/sgu-507-treediff\/","title":{"rendered":"SGU 507. Treediff"},"content":{"rendered":"<h3>Brief description: <\/h3>\n<p>\u7ed9\u5b9a\u4e00\u68f5 n \u4e2a\u7ed3\u70b9\u7684\u6811\uff0c\u53f6\u8282\u70b9\u6709\u4e00\u4e2a\u6743\u503c\uff0c\u95ee\u4ee5\u6bcf\u4e2a\u5185\u7ed3\u70b9\u4e3a\u6839\u7684\u5b50\u6811\uff0c\u6240\u6709\u53f6\u8282\u70b9\u4e4b\u95f4\u6743\u503c\u5dee\u6700\u5c0f\u7684\u503c\u3002<br \/>\n( n <= 50000 )\n<!--more--><\/p>\n<h3>Analysis: <\/h3>\n<p>&#8230; . \u542f\u53d1\u5f0f\u5408\u5e76\u3002\u3002<\/p>\n<pre class=\"brush: cpp; light: false; title: ; toolbar: true; notranslate\" title=\"\">\r\nconst int N = 50009;\r\n\r\nSI S&#x5B;N]; queue&lt;int&gt; Q;\r\nint p&#x5B;N], c&#x5B;N], h&#x5B;N], res&#x5B;N], n, m;\r\n\r\n\r\nint main(){\r\n\r\n    \/\/freopen(&quot;in.txt&quot;, &quot;r&quot;, stdin);\r\n\r\n    RD(n, m); fill(res, res + n, 0x7fffffff); FOR(i, 1, n) ++c&#x5B;--_RD(p&#x5B;i])];\r\n\r\n    REP(i, n) h&#x5B;i] = i; FOR(i, n - m, n) S&#x5B;i].insert(RD()), Q.push(i);\r\n\r\n    while (!Q.empty()){\r\n        int u = Q.front(); Q.pop();\r\n\r\n#define uu h&#x5B;u]\r\n#define v p&#x5B;u]\r\n#define vv h&#x5B;v]\r\n\r\n        if (SZ(S&#x5B;vv]) &lt; SZ(S&#x5B;uu])) swap(uu, vv);\r\n\r\n        if (S&#x5B;vv].empty()){\r\n            res&#x5B;v] = res&#x5B;u];\r\n            vv = uu;\r\n        }\r\n        else {\r\n\r\n            checkMin(res&#x5B;v], res&#x5B;u]);\r\n\r\n            \/*\r\n            SI::iterator jt, kt; pair&lt;SI::iterator, bool&gt; tmp; ECH(it, S&#x5B;uu]){\r\n                tmp = S&#x5B;vv].insert(*it); if (!tmp.second) {res&#x5B;v] = 0; break;}\r\n                else {\r\n                    jt = tmp.first;\r\n                    if (jt != S&#x5B;vv].begin()) kt = jt, --kt, checkMin(res&#x5B;v], *jt - *kt);\r\n                    kt = jt; ++kt; if (kt != S&#x5B;vv].end()) checkMin(res&#x5B;v], *kt - *jt);\r\n                }\r\n            }\r\n            *\/\r\n\r\n            \r\n            SI::iterator jt; ECH(it, S&#x5B;uu]){\r\n                SI::iterator jt = S&#x5B;vv].lower_bound(*it);\r\n                if(jt != S&#x5B;vv].end()) res&#x5B;v] = min(res&#x5B;v], *jt - *it);\r\n                if(jt != S&#x5B;vv].begin()) res&#x5B;v] = min(res&#x5B;v], *it - *--jt);                \r\n                if (!res&#x5B;v]) break;\r\n            }\r\n\r\n            if (res&#x5B;v]) ECH(it, S&#x5B;uu]) S&#x5B;vv].insert(*it);\r\n\r\n        }\r\n\r\n        if (!--c&#x5B;v] &amp;&amp; v) Q.push(v);\r\n    }\r\n\r\n    REP(i, n - m) cout &lt;&lt; res&#x5B;i] &lt;&lt; &quot; &quot;;\r\n    cout &lt;&lt; endl;\r\n}\r\n<\/pre>\n<h3>External link: <\/h3>\n<p><a href=\"http:\/\/acm.sgu.ru\/problem.php?contest=0&#038;problem=507\">http:\/\/acm.sgu.ru\/problem.php?contest=0&#038;problem=507<\/a><\/p>\n","protected":false},"excerpt":{"rendered":"<p>Brief description: \u7ed9\u5b9a\u4e00\u68f5 n \u4e2a\u7ed3\u70b9\u7684\u6811\uff0c\u53f6\u8282\u70b9\u6709\u4e00\u4e2a\u6743\u503c\uff0c\u95ee\u4ee5\u6bcf\u4e2a\u5185\u7ed3\u70b9\u4e3a\u6839\u7684\u5b50\u6811\uff0c\u6240\u6709\u53f6\u8282\u70b9\u4e4b\u95f4\u6743\u503c\u5dee\u6700\u5c0f\u7684\u503c\u3002 ( n<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"jetpack_post_was_ever_published":false,"_jetpack_newsletter_access":"","_jetpack_dont_email_post_to_subs":false,"_jetpack_newsletter_tier_id":0,"_jetpack_memberships_contains_paywalled_content":false,"_jetpack_memberships_contains_paid_content":false,"footnotes":"","jetpack_publicize_message":"","jetpack_publicize_feature_enabled":true,"jetpack_social_post_already_shared":false,"jetpack_social_options":{"image_generator_settings":{"template":"highway","enabled":false}}},"categories":[61],"tags":[],"class_list":["post-166","post","type-post","status-publish","format-standard","hentry","category-sgu"],"jetpack_publicize_connections":[],"jetpack_featured_media_url":"","jetpack_shortlink":"https:\/\/wp.me\/p2tdP7-2G","jetpack_sharing_enabled":true,"_links":{"self":[{"href":"https:\/\/www.shuizilong.com\/house\/wp-json\/wp\/v2\/posts\/166","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/www.shuizilong.com\/house\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.shuizilong.com\/house\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.shuizilong.com\/house\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/www.shuizilong.com\/house\/wp-json\/wp\/v2\/comments?post=166"}],"version-history":[{"count":0,"href":"https:\/\/www.shuizilong.com\/house\/wp-json\/wp\/v2\/posts\/166\/revisions"}],"wp:attachment":[{"href":"https:\/\/www.shuizilong.com\/house\/wp-json\/wp\/v2\/media?parent=166"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.shuizilong.com\/house\/wp-json\/wp\/v2\/categories?post=166"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.shuizilong.com\/house\/wp-json\/wp\/v2\/tags?post=166"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}