📜  计算树大小的迭代程序

📅  最后修改于: 2022-05-13 01:57:19.491000             🧑  作者: Mango

计算树大小的迭代程序

树的大小是树中存在的元素的数量。下面的树的大小是 5。

示例树

方法
这个想法是使用 Level Order Traversing

1) Create an empty queue q
2) temp_node = root /*start from root*/
3) Loop while temp_node is not NULL
    a) Enqueue temp_node’s children (first left then right children) to q
    b) Increase count with every enqueuing.
    c) Dequeue a node from q and assign it’s value to temp_node

C++
// C++ program to print size of tree in iterative
#include
#include
using namespace std;
 
struct Node
{
    int data;
    Node *left, *right;
};
 
// A utility function to
// create a new Binary Tree Node
Node *newNode(int data)
{
    Node *temp = new Node;
    temp->data = data;
    temp->left = NULL;
    temp->right = NULL;
     
    return temp;
}
 
// return size of tree
int sizeoftree(Node *root)
{
 
    // if tree is empty it will
    // return 0
    if(root == NULL)
        return 0;
     
     
    // Using level order Traversal.
    queue q;
    int count = 1;
    q.push(root);
     
    while(!q.empty())
    {
        Node *temp = q.front();
     
        if(temp->left)
        {
            // Enqueue left child
            q.push(temp->left);
             
            // Increment count
            count++;
        }
     
        if(temp->right)
        {
            // Enqueue right child
            q.push(temp->right);
             
            // Increment count
            count++;
        }
        q.pop();
    }
     
    return count;
}
 
// Driver Code
int main()
{
    Node *root = newNode(1);
    root->left = newNode(2);
    root->right = newNode(3);
    root->left->left = newNode(4);
    root->left->right = newNode(5);
 
    cout << "Size of the tree is " <<
        sizeoftree(root) << endl;
    return 0;
}
 
// This code is contributed by SHAKEELMOHAMMAD


Java
// Java programn to calculate
// Size of a tree
import java.util.LinkedList;
import java.util.Queue;
 
class Node
{
    int data;
    Node left, right;
 
    public Node(int item)
    {
        data = item;
        left = right = null;
    }
}
 
class BinaryTree
{
    Node root;
         
    public int size()
    {
        if (root == null)
            return 0;
         
        // Using level order Traversal.
        Queue q = new LinkedList();
        q.offer(root);
         
        int count = 1;
        while (!q.isEmpty())
        {
            Node tmp = q.poll();
     
            // when the queue is empty:
            // the poll() method returns null.
            if (tmp != null)
            {
                if (tmp.left != null)
                {
                    // Increment count
                    count++;
                     
                    // Enqueue left child
                    q.offer(tmp.left);
                }
                if (tmp.right != null)
                {
                    // Increment count
                    count++;
                     
                    // Enqueue left child
                    q.offer(tmp.right);
                }
            }
        }
         
        return count;
    }
 
    public static void main(String args[])
    {
        /* creating a binary tree and entering
          the nodes */
        BinaryTree tree = new BinaryTree();
        tree.root = new Node(1);
        tree.root.left = new Node(2);
        tree.root.right = new Node(3);
        tree.root.left.left = new Node(4);
        tree.root.left.right = new Node(5);
 
        System.out.println("The size of binary tree" +
                         " is : " + tree.size());
    }
}


Python3
# Python Program to calculate size of the tree iteratively
 
# Node Structure
class newNode:
    def __init__(self,data):
        self.data = data
        self.left = self.right = None
         
# Return size of tree
def sizeoftree(root):
    if root == None:
        return 0
    q = []
    q.append(root)
    count = 1
    while(len(q) != 0):
        root = q.pop(0)
        if(root.left):
            q.append(root.left)
            count += 1
        if(root.right):
            q.append(root.right)
            count += 1
    return count
     
# Driver Program
root = newNode(1)
root.left = newNode(2)
root.right = newNode(3)
root.left.left = newNode(4)
root.left.right = newNode(5)
print(sizeoftree(root))
 
# This is code is contributed by simranjenny84


C#
// C# programn to calculate
// Size of a tree
using System;
using System.Collections.Generic;
 
public class Node
{
    public int data;
    public Node left, right;
 
    public Node(int item)
    {
        data = item;
        left = right = null;
    }
}
 
public class BinaryTree
{
    Node root;
         
    public int size()
    {
        if (root == null)
            return 0;
         
        // Using level order Traversal.
        Queue q = new Queue();
        q.Enqueue(root);
         
        int count = 1;
        while (q.Count != 0)
        {
            Node tmp = q.Dequeue();
     
            // when the queue is empty:
            // the poll() method returns null.
            if (tmp != null)
            {
                if (tmp.left != null)
                {
                    // Increment count
                    count++;
                     
                    // Enqueue left child
                    q.Enqueue(tmp.left);
                }
                if (tmp.right != null)
                {
                    // Increment count
                    count++;
                     
                    // Enqueue left child
                    q.Enqueue(tmp.right);
                }
            }
        }
         
        return count;
    }
 
    // Driver code
    public static void Main(String []args)
    {
        /* creating a binary tree and entering
        the nodes */
        BinaryTree tree = new BinaryTree();
        tree.root = new Node(1);
        tree.root.left = new Node(2);
        tree.root.right = new Node(3);
        tree.root.left.left = new Node(4);
        tree.root.left.right = new Node(5);
 
        Console.WriteLine("The size of binary tree" +
                        " is : " + tree.size());
    }
}
 
// This code has been contributed by 29AjayKumar


Javascript

 
    // JavaScript programn to calculate Size of a tree
     
    class Node
    {
        constructor(item) {
           this.left = null;
           this.right = null;
           this.data = item;
        }
    }
     
    let root;
           
    function size()
    {
        if (root == null)
            return 0;
           
        // Using level order Traversal.
        let q = [];
        q.push(root);
           
        let count = 1;
        while (q.length > 0)
        {
            let tmp = q[0];
            q.shift();
       
            // when the queue is empty:
            // the poll() method returns null.
            if (tmp != null)
            {
                if (tmp.left != null)
                {
                    // Increment count
                    count++;
                       
                    // Enqueue left child
                    q.push(tmp.left);
                }
                if (tmp.right != null)
                {
                    // Increment count
                    count++;
                       
                    // Enqueue left child
                    q.push(tmp.right);
                }
            }
        }
           
        return count;
    }
     
    /* creating a binary tree and entering
            the nodes */
    root = new Node(1);
    root.left = new Node(2);
    root.right = new Node(3);
    root.left.left = new Node(4);
    root.left.right = new Node(5);
 
    document.write("Size of the tree is " + size());
     
Size of the tree is 5


输出:

Size of the tree is 5

时间复杂度: O(n)
辅助空间: O(level_max),其中 level max 是任何级别中的最大节点数。