算法 - 如何不用递归 列出 树(多叉) 中根节点到叶节点的所有路径(Java)
天蓬老师
天蓬老师 2017-04-18 10:51:58
0
4
613

比如,对于下面这个二叉树,它所有的路径为:

8 -> 3 -> 1

8 -> 2 -> 6 -> 4

8 -> 3 -> 6 -> 7

8 -> 10 -> 14 -> 13

怎么用Java去实现?

天蓬老师
天蓬老师

欢迎选择我的课程,让我们一起见证您的进步~~

全部回覆(4)
阿神

不用遞歸的話,那就深度優先!
採用棧, 先將根結點壓入棧,如果棧不為空,而後出棧並輸出當前結點中值,而後先把右子樹壓入棧,再把左子樹壓入棧,再判斷棧是否為空,循環.....
步驟如下:
1) 先把二元樹的根結點入棧
2)判斷棧是否為空,不為空,則出棧,並輸出出棧樹結點的值
3)出棧樹結點的右子樹入棧
4)出棧樹結點的左子樹入棧
5)循環回到(2)
這是我之前看到的一個方法,不知道能不能幫到題主?

public void depthOrderTraversal(){  
        if(root==null){  
            System.out.println("empty tree");  
            return;  
        }         
        ArrayDeque<TreeNode> stack=new ArrayDeque<TreeNode>();  
        stack.push(root);         
        while(stack.isEmpty()==false){  
            TreeNode node=stack.pop();  
            System.out.print(node.value+"    ");  
            if(node.right!=null){  
                stack.push(node.right);  
            }  
            if(node.left!=null){  
                stack.push(node.left);  
            }             
        }  
        System.out.print("\n");  
    }  
Ty80

用棧替代遞歸:https://zh.coursera.org/learn...

大家讲道理

深度優先? 。 。

洪涛

使用廣度優先遍歷,然後狀態儲存該節點的所有父節點,到葉子節點後輸出。

熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板
關於我們 免責聲明 Sitemap
PHP中文網:公益線上PHP培訓,幫助PHP學習者快速成長!