樹的同構 java


import
java.util.Scanner; //創造節點類型 class Node { String key; int left; int right; } class test { public static void main(String[] args) { Scanner sc=new Scanner(System.in); Node[] arr1=new Node[8]; Node[] arr2=new Node[8]; int head1=biuldTree(arr1, sc); int head2=biuldTree(arr2, sc); boolean result=isTonggou(arr1,head1,arr2,head2); if (result) { System.out.print("Yes"); } else { System.out.print("No"); } } public static int biuldTree(Node[] arr,Scanner sc) { int N=sc.nextInt(); String templeft; String tempright; int[] flag=new int[N]; int root=0; for (int i=0;i<N ;i++ ) { Node node=new Node(); node.key=sc.next(); templeft=sc.next(); tempright=sc.next(); arr[i]=node; if (templeft.equals("-")) { node.left=-1; } else { node.left=Integer.parseInt(templeft); flag[node.left]=1; } if (tempright.equals("-")) { node.right=-1; } else { node.right=Integer.parseInt(tempright); flag[node.right]=1; } for (int j=0;j<N ;j++ ) { if (flag[j]==0) { root=j; } } } return root; } public static boolean isTonggou(Node[] arr1,int head1,Node[] arr2,int head2) { //遞歸出口 if ((head1==-1) &&( head2==-1)) {return true;} if ((head1==-1) && (head2 !=-1) || (head1!=-1) && (head2==-1)) {return false;} if (!(arr1[head1].key.equals(arr2[head2].key))) {return false;} //樹1和樹2的左孩子都爲空,判斷右孩子爲根節點的樹是否是同構 if ((arr1[head1].left==-1) && (arr2[head2].left==-1)) { return isTonggou(arr1,arr1[head1].right, arr2, arr2[head2].right); } //若是樹1的左孩子不空,樹2的左孩子也不空,而且兩個左孩子的key相等,那麼判斷以左孩子爲根的樹是否同構,以右孩子爲根的樹是否同構 if ((arr1[head1].left != -1 )&&( arr2[head2].left != -1 )&& (arr1[arr1[head1].left].key.equals((arr2[arr2[head2].left].key)) )) { return (isTonggou(arr1, arr1[head1].left,arr2, arr2[head2].left)&&(isTonggou(arr1,arr1[head1].right,arr2,arr2[head2].right))); } //若是上述都不知足,那麼判斷以樹1的左孩子和樹2的右孩子爲根的樹是否同構,判斷以樹1的右孩子和樹2的左孩子爲根的樹是否同構 else { return (isTonggou(arr1, arr1[head1].left,arr2, arr2[head2].right)&&(isTonggou(arr1,arr1[head1].right,arr2,arr2[head2].left))); } } }

實驗結果java

採用結構數組來儲存節點,將孩子爲空標記爲-1.node

Yes和No前面的樹分別標記兩顆樹的根所在的位置,是我調試時加上以便判斷哪一個地方出問題的。數組

相關文章
相關標籤/搜索