{"id":45292,"date":"2023-12-11T15:05:25","date_gmt":"2023-12-11T07:05:25","guid":{"rendered":"https:\/\/wx.kaifamiao.info\/?p=45292"},"modified":"2023-12-11T15:05:25","modified_gmt":"2023-12-11T07:05:25","slug":"%e5%a6%82%e4%bd%95%e6%89%93%e5%8d%b0%e4%ba%8c%e5%8f%89%e6%a0%91%e6%af%8f%e5%b1%82%e7%9a%84%e8%8a%82%e7%82%b9%ef%bc%9f-2","status":"publish","type":"post","link":"http:\/\/wx.kaifamiao.info\/index.php\/2023\/12\/11\/%e5%a6%82%e4%bd%95%e6%89%93%e5%8d%b0%e4%ba%8c%e5%8f%89%e6%a0%91%e6%af%8f%e5%b1%82%e7%9a%84%e8%8a%82%e7%82%b9%ef%bc%9f-2\/","title":{"rendered":"\u5982\u4f55\u6253\u5370\u4e8c\u53c9\u6811\u6bcf\u5c42\u7684\u8282\u70b9\uff1f"},"content":{"rendered":"<p>&#8220;`&#8221;                    \u8003\u5bdf\u70b9\uff1a\u4e8c\u53c9\u6811<\/p>\n<p>\u00a0<\/p>\n<p>\u5b9e\u73b0\u4ee3\u7801\uff1a<\/p>\n<p>&lt;pre&gt;&lt;code class=&quot;&quot;language-java&quot;&quot; lang=&quot;&quot;java&quot;&quot;&gt;import<br \/>\njava.util.ArrayList;<br \/>\nimport<br \/>\njava.util.Scanner;<br \/>\npublic class Main<br \/>\n{<br \/>\n    \/\/ \u5b9a\u4e49\u8282\u70b9<br \/>\n    class Node{<br \/>\n        int val;<br \/>\n        Node left;<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();<br \/>\n     }<\/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            \/\/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\u4ee3\u7801\uff1a &lt;pre&gt;&lt;code cla [&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-45292","post","type-post","status-publish","format-standard","hentry","category-c"],"_links":{"self":[{"href":"http:\/\/wx.kaifamiao.info\/index.php\/wp-json\/wp\/v2\/posts\/45292","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=45292"}],"version-history":[{"count":1,"href":"http:\/\/wx.kaifamiao.info\/index.php\/wp-json\/wp\/v2\/posts\/45292\/revisions"}],"predecessor-version":[{"id":45293,"href":"http:\/\/wx.kaifamiao.info\/index.php\/wp-json\/wp\/v2\/posts\/45292\/revisions\/45293"}],"wp:attachment":[{"href":"http:\/\/wx.kaifamiao.info\/index.php\/wp-json\/wp\/v2\/media?parent=45292"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"http:\/\/wx.kaifamiao.info\/index.php\/wp-json\/wp\/v2\/categories?post=45292"},{"taxonomy":"post_tag","embeddable":true,"href":"http:\/\/wx.kaifamiao.info\/index.php\/wp-json\/wp\/v2\/tags?post=45292"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}