{"id":45294,"date":"2023-12-11T15:05:25","date_gmt":"2023-12-11T07:05:25","guid":{"rendered":"https:\/\/wx.kaifamiao.info\/?p=45294"},"modified":"2023-12-11T15:05:25","modified_gmt":"2023-12-11T07:05:25","slug":"%e5%a6%82%e4%bd%95%e7%9f%a5%e9%81%93%e4%ba%8c%e5%8f%89%e6%a0%91%e7%9a%84%e6%b7%b1%e5%ba%a6%ef%bc%9f-2","status":"publish","type":"post","link":"http:\/\/wx.kaifamiao.info\/index.php\/2023\/12\/11\/%e5%a6%82%e4%bd%95%e7%9f%a5%e9%81%93%e4%ba%8c%e5%8f%89%e6%a0%91%e7%9a%84%e6%b7%b1%e5%ba%a6%ef%bc%9f-2\/","title":{"rendered":"\u5982\u4f55\u77e5\u9053\u4e8c\u53c9\u6811\u7684\u6df1\u5ea6\uff1f"},"content":{"rendered":"<p>&#8220;`&#8221;                    \u8003\u5bdf\u70b9\uff1a\u4e8c\u53c9\u6811<\/p>\n<p>\u00a0<\/p>\n<p>\u5b9e\u73b0\u4e8c\u53c9\u6811\u7684\u6df1\u5ea6\u65b9\u5f0f\u6709\u4e24\u79cd\uff0c\u9012\u5f52\u4ee5\u53ca\u975e\u9012\u5f52\u3002<\/p>\n<p>\u2460\u9012\u5f52\u5b9e\u73b0\uff1a<\/p>\n<p>\u4e3a\u4e86\u6c42\u6811\u7684\u6df1\u5ea6\uff0c\u53ef\u4ee5\u5148\u6c42\u5176\u5de6\u5b50\u6811\u7684\u6df1\u5ea6\u548c\u53f3\u5b50\u6811\u7684\u6df1\u5ea6\uff0c\u53ef\u4ee5\u7528\u9012\u5f52\u5b9e\u73b0\uff0c\u9012\u5f52\u7684\u51fa\u53e3\u5c31\u662f\u8282\u70b9\u4e3a\u7a7a\u3002\u8fd4\u56de\u503c\u4e3a0\uff1b<\/p>\n<p>\u2461\u975e\u9012\u5f52\u5b9e\u73b0\uff1a<\/p>\n<p>\u5229\u7528\u5c42\u6b21\u904d\u5386\u7684\u7b97\u6cd5\uff0c\u8bbe\u7f6e\u53d8\u91cflevel\u8bb0\u5f55\u5f53\u524d\u8282\u70b9\u6240\u5728\u7684\u5c42\u6570\uff0c\u8bbe\u7f6e\u53d8\u91cflast\u6307\u5411\u5f53\u524d\u5c42\u7684\u6700\u540e\u4e00\u4e2a\u8282\u70b9\uff0c\u5f53\u5904\u7406\u5b8c\u5f53\u524d\u5c42\u7684\u6700\u540e\u4e00\u4e2a\u8282\u70b9\uff0c\u8ba9level\u6307\u5411+1\u64cd\u4f5c\u3002\u8bbe\u7f6e\u53d8\u91cfcur\u8bb0\u5f55\u5f53\u524d\u5c42\u5df2\u7ecf\u8bbf\u95ee\u7684\u8282\u70b9\u7684\u4e2a\u6570\uff0c\u5f53cur\u7b49\u4e8elast\u65f6\uff0c\u8868\u793a\u8be5\u5c42\u8bbf\u95ee\u7ed3\u675f\u3002<\/p>\n<p>\u5c42\u6b21\u904d\u5386\u5728\u6c42\u6811\u7684\u5bbd\u5ea6\u3001\u8f93\u51fa\u67d0\u4e00\u5c42\u8282\u70b9\uff0c\u67d0\u4e00\u5c42\u8282\u70b9\u4e2a\u6570\uff0c\u6bcf\u4e00\u5c42\u8282\u70b9\u4e2a\u6570\u90fd\u53ef\u4ee5\u91c7\u53d6\u7c7b\u4f3c\u7684\u7b97\u6cd5\u3002<\/p>\n<p>\u6811\u7684\u5bbd\u5ea6\uff1a\u5728\u6811\u7684\u6df1\u5ea6\u7b97\u6cd5\u57fa\u7840\u4e0a\uff0c\u52a0\u4e00\u4e2a\u8bb0\u5f55\u8bbf\u95ee\u8fc7\u7684\u5c42\u8282\u70b9\u4e2a\u6570\u6700\u591a\u7684\u53d8\u91cfmax,\u5728\u8bbf\u95ee\u6bcf\u5c42\u524dmax\u4e0elast\u6bd4\u8f83\uff0c\u5982\u679cmax\u6bd4\u8f83\u5927\uff0cmax\u4e0d\u53d8\uff0c\u5982\u679cmax\u5c0f\u4e8elast\uff0c\u628alast\u8d4b\u503c\u7ed9max;<\/p>\n<p>\u4ee3\u7801\u89e3\u91ca\uff1a<\/p>\n<p>&lt;pre&gt;&lt;code class=&quot;&quot;language-java&quot;&quot; lang=&quot;&quot;java&quot;&quot;&gt;import java.util.ArrayList;<br \/>\nimport java.util.Scanner;<br \/>\npublic class Main<br \/>\n{<br \/>\n    \/\/ \u5b9a\u4e49\u8282\u70b9<br \/>\n    class Node{<br \/>\n        int val;<br \/>\n        Nodeleft;<br \/>\n        Node right;<br \/>\n        public Node(int val) {<br \/>\n            this.val = val;<br \/>\n        }<br \/>\n    }<\/p>\n<p>    public ArrayList&lt;Integer&gt; gzy; \/\/ \u4fdd\u5b58\u6839\u5de6\u53f3\u7684\u5e8f\u5217<br \/>\n    public ArrayList&lt;Integer&gt; zgy; \/\/ \u4fdd\u5b58\u5de6\u8ddf\u53f3\u7684\u5e8f\u5217<br \/>\n    public ArrayList&lt;Node&gt; pack;       \/\/ \u4fdd\u5b58\u5df2\u7ecf\u6392\u597d\u7684\u8282\u70b9<\/p>\n<p>    public static void main(String[] args) {<br \/>\n        Main main = new Main();<br \/>\n        main.getResult();<\/p>\n<p>    }<\/p>\n<p>    public void getResult() {<br \/>\n        \/\/init Scanner<br \/>\n        scanner = new Scanner(System.in);<br \/>\n        int count = scanner.nextInt();<br \/>\n        gzy = new ArrayList&lt;&gt;();<br \/>\n        zgy = new ArrayList&lt;&gt;();<br \/>\n        for(int i = 0; i &lt; count; i++) {<br \/>\n            gzy.add(scanner.nextInt());<br \/>\n        }<br \/>\n        for(int j = 0; j &lt; count; j++) {<br \/>\n            zgy.add(scanner.nextInt());<br \/>\n        }<br \/>\n        pack= new ArrayList&lt;&gt;();       \/\/ \u5df2\u7ecf\u8fd8\u539f\u7684\u8282\u70b9<\/p>\n<p>        \/\/exception<br \/>\n        if(count== 1) {<br \/>\n            System.out.println(gzy.get(0));<br \/>\n            return;<br \/>\n        }<br \/>\n        \/\/ \u6784\u9020\u6700\u5de6\u4fa7\u8282\u70b9\u7684\u4e8c\u53c9\u6811<br \/>\n        Node node = new Node(gzy.get(0));<br \/>\n        pack.add(node);<br \/>\n        int index1 = 1;     \/\/ \u6839\u5de6\u53f3\u7684\u4e0b\u6807<br \/>\n        Node tmp = node;<br \/>\n        while(gzy.get(index1) != zgy.get(0)) {      \/\/ \u5982\u679c\u6ca1\u8bbf\u95ee\u5230\u6700\u5de6\u8fb9\u7684\u53f6\u5b50\u8282\u70b9,\u7ee7\u7eed\u8fd8\u539f\u6700\u5de6\u4fa7\u4e8c\u53c9\u6811<br \/>\n            tmp.left = new Node(gzy.get(index1++));<br \/>\n            tmp = tmp.left;<br \/>\n            pack.add(tmp);<br \/>\n        }<br \/>\n        tmp.left = new Node(gzy.get(index1++));<br \/>\n        pack.add(tmp.left);<\/p>\n<p>        \/\/ \u52a0\u5165\u5269\u4f59\u7684\u8282\u70b9\u5b8c\u5584\u4e8c\u53c9\u6811<br \/>\n        for(int k = index1; k &lt; gzy.size(); k++) {<br \/>\n            fillErCS(gzy.get(k));<br \/>\n        }<\/p>\n<p>        \/\/ \u5c42\u6b21\u904d\u5386<br \/>\n        ArrayList&lt;Node&gt; res = new ArrayList&lt;&gt;();<br \/>\n        res.add(node);<br \/>\n        int num = 0;<br \/>\n        while(res.size()!= num) {<br \/>\n            System.out.print(res.get(num).val + &quot;&quot;&quot;&quot;);<br \/>\n            if(res.get(num).left != null) {<br \/>\n                res.add(res.get(num).left);<br \/>\n            }<br \/>\n            if(res.get(num).right != null) {<br \/>\n                res.add(res.get(num).right);<br \/>\n            }<br \/>\n            num++;<br \/>\n        }<br \/>\n    }<\/p>\n<p>    \/\/ \u5c06\u503c\u4e3aval\u7684\u8282\u70b9\u52a0\u5165\u4e8c\u53c9\u6811<br \/>\n    private void fillErCS(int val) {<br \/>\n        int index = zgy.indexOf(val);<br \/>\n        \/\/ \u6bcf\u4e00\u4e2a\u904d\u5386\u7684\u8282\u70b9\u90fd\u662fval\u8282\u70b9\u7684\u6839\u6216\u8005\u5728\u5176\u5de6\u8fb9<br \/>\n        for(int i = index-1; i &gt;= 0; i&#8211;) {<br \/>\n            if(findNode(zgy.get(i)) != null) {  \/\/ \u627e\u5230\u5f85\u63d2\u5165\u8282\u70b9\u7684\u6839\u8282\u70b9\u6216\u8005\u5176\u5de6\u8fb9\u7684\u8282\u70b9<br \/>\n                Node node = findNode(zgy.get(i));<br \/>\n                insert(node,val);<br \/>\n                break;<br \/>\n            }<br \/>\n        }<br \/>\n    }<\/p>\n<p>    \/\/ \u5c06\u8282\u70b9val\u63d2\u5165\u4e8c\u53c9\u6811<br \/>\n    private void insert(Node node, int val) {<br \/>\n        if(zgy.indexOf(node.val)&gt; zgy.indexOf(val)) {  \/\/ node\u5728\u5f85\u63d2\u5165\u8282\u70b9\u7684\u53f3\u8fb9<br \/>\n            if(node.left == null) {<br \/>\n                node.left= new Node(val);<br \/>\n                pack.add(node.left);<br \/>\n                return;<br \/>\n            }<br \/>\n            insert(node.left, val);<br \/>\n        }<br \/>\n        else<br \/>\n        {<br \/>\n            \/\/node\u5728\u5f85\u63d2\u5165\u8282\u70b9\u7684\u5de6\u8fb9\u6216\u662f\u5176\u6839<br \/>\n            if(node.right == null) {<br \/>\n                node.right= new Node(val);<br \/>\n                pack.add(node.right);<br \/>\n                return;<br \/>\n            }<br \/>\n            insert(node.right, val);<br \/>\n        }<br \/>\n    }<br \/>\n    \/\/ \u6839\u636eval\u627e\u5230pack\u91cc\u7684\u8282\u70b9<br \/>\n    private Node findNode(int val) {<br \/>\n        for(Node node : pack) {<br \/>\n            if(node.val == val) {<br \/>\n                return node;<br \/>\n            }<br \/>\n        }<br \/>\n        return null;<br \/>\n    }<br \/>\n}<br \/>\n&lt;\/code&gt;&lt;\/pre&gt;<\/p>\n<p>\u00a0<\/p>\n<p>&lt;pre&gt;&lt;code&gt;            &quot;&#8220;`<br \/>\n<\/code><\/pre>\n","protected":false},"excerpt":{"rendered":"<p>&#8220;`&#8221; \u8003\u5bdf\u70b9\uff1a\u4e8c\u53c9\u6811 \u00a0 \u5b9e\u73b0\u4e8c\u53c9\u6811\u7684\u6df1\u5ea6\u65b9\u5f0f\u6709\u4e24\u79cd\uff0c\u9012\u5f52\u4ee5\u53ca\u975e\u9012\u5f52\u3002 \u2460\u9012\u5f52\u5b9e\u73b0\uff1a [&hellip;]<\/p>\n","protected":false},"author":7,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[101],"tags":[],"class_list":["post-45294","post","type-post","status-publish","format-standard","hentry","category-c"],"_links":{"self":[{"href":"http:\/\/wx.kaifamiao.info\/index.php\/wp-json\/wp\/v2\/posts\/45294","targetHints":{"allow":["GET"]}}],"collection":[{"href":"http:\/\/wx.kaifamiao.info\/index.php\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"http:\/\/wx.kaifamiao.info\/index.php\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"http:\/\/wx.kaifamiao.info\/index.php\/wp-json\/wp\/v2\/users\/7"}],"replies":[{"embeddable":true,"href":"http:\/\/wx.kaifamiao.info\/index.php\/wp-json\/wp\/v2\/comments?post=45294"}],"version-history":[{"count":1,"href":"http:\/\/wx.kaifamiao.info\/index.php\/wp-json\/wp\/v2\/posts\/45294\/revisions"}],"predecessor-version":[{"id":45295,"href":"http:\/\/wx.kaifamiao.info\/index.php\/wp-json\/wp\/v2\/posts\/45294\/revisions\/45295"}],"wp:attachment":[{"href":"http:\/\/wx.kaifamiao.info\/index.php\/wp-json\/wp\/v2\/media?parent=45294"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"http:\/\/wx.kaifamiao.info\/index.php\/wp-json\/wp\/v2\/categories?post=45294"},{"taxonomy":"post_tag","embeddable":true,"href":"http:\/\/wx.kaifamiao.info\/index.php\/wp-json\/wp\/v2\/tags?post=45294"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}