当前位置:编程学习 > C/C++ >>

微软等数据结构与算法面试100题 第四题

第四题

题目:输入一个整数和一棵二元树。
从树的根结点开始往下访问一直到叶结点所经过的所有结点形成一条路径。
打印出和与输入整数相等的所有路径。
例如 输入整数22和如下二元树
  10 
  / \  
 5  12  
 /   \  
4     7
则打印出两条路径:10, 12和10, 5, 7。

分析:(本人拙见)
这道题目主要考察的是二叉树的非递归周游,因此很容易想到使用栈来作为数据遍历的时候的节点存储。每次压入栈数据的时候判断是否达到了叶节点且栈中元素之和
满足给定值,如果满足上面两个条件,为真,打印栈中的元素。继续遍历。

首先是树的构建,为了方便这里使用了广度优先的插入算法,跟这道题木有太大关系。
然后就是对于二叉树的非递归周游。

[cpp] 
#include<iostream> 
#include<queue> 
#include<stack> 
using namespace std; 
 
typedef struct NodeBinaryTree 

    int value; 
    NodeBinaryTree * nodeLeft; 
    NodeBinaryTree * nodeRight; 
}NodeBinaryTree; 
 
class BinaryTree 

private: 
    NodeBinaryTree * root; 
    stack<int> Path; 
public: 
 
    BinaryTree(); 
    //~BSTree(); 这个地方需要递归delete所有节点 
    NodeBinaryTree * Root(){return root;} 
    void addNodeBSTree(const int item); 
    void inOrder(NodeBinaryTree * root); 
      
    void inOrderStack(const int item); 
}; 
 
BinaryTree::BinaryTree() 

    root = NULL; 

 
void BinaryTree::addNodeBSTree(const int item) 

    //这个地方写代码的时候使用了广度优先的插入节点,当时不知道怎么想的就写了这个 
    //与本题关系不大,可以直接忽略 
    if(NULL==root) 
    { 
     
        NodeBinaryTree * node2add = new NodeBinaryTree(); 
        node2add->value = item; 
        node2add->nodeLeft = NULL; 
        node2add->nodeRight = NULL; 
        root = node2add; 
    } 
    else 
    { 
        //BinaryTree的节点的插入采用的是广度优先的插入方式,因此这里我们定义了一个队列,直接采用了STL里面的队列 
        using std::queue; 
        queue<NodeBinaryTree *> aQueue; 
        NodeBinaryTree * pointer = root; 
        if(pointer) 
            aQueue.push(pointer); 
        while(!aQueue.empty()) 
        { 
            pointer = aQueue.front(); 
            aQueue.pop(); 
            if(NULL!=pointer->nodeLeft && NULL!=pointer->nodeRight){//为什么书上这个地方有括号 
                aQueue.push(pointer->nodeLeft); 
                aQueue.push(pointer->nodeRight); 
            } 
            else if(NULL!=pointer->nodeLeft && NULL==pointer->nodeRight) 
            { 
                //找到当前的没有右子树的点,将待加入的点插入的右子树 
                NodeBinaryTree * node2add = new NodeBinaryTree(); 
                pointer->nodeRight = node2add;  
                node2add->value = item; 
                node2add->nodeLeft = NULL; 
                node2add->nodeRight = NULL; 
                break; 
            } 
            else //说明是左子树是NULL 
            { 
                NodeBinaryTree * node2add = new NodeBinaryTree(); 
                pointer->nodeLeft = node2add;  
                node2add->value = item; 
                node2add->nodeLeft = NULL; 
                node2add->nodeRight = NULL; 
                break; 
            } 
 
     
        } 
    } 
 

 
void BinaryTree::inOrder(NodeBinaryTree * root) 

    if(NULL!=root) 
    { 
        inOrder(root->nodeLeft); 
        cout<<root->value<<" "; 
        inOrder(root->nodeRight); 
    } 

 
void BinaryTree::inOrderStack(const int item) 

    cout<<"the expected sum of the path is "<<item<<endl; 
    NodeBinaryTree * root = this->root; 
    //非递归周游二叉树  
    enum Tags{Left,Right}; 
    struct StackElement 
    { 
        NodeBinaryTree * pointer; 
        Tags tag; 
    }; 
 
  

补充:软件开发 , C++ ,
CopyRight © 2012 站长网 编程知识问答 www.zzzyk.com All Rights Reserved
部份技术文章来自网络,