热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

计算n叉树中各节点子树的叶节点数量分析

n 元树每个节点的子树中的叶节点数原文:https://www . geesforgeks . org/n 元树的每个节点的子树

n 元树每个节点的子树中的叶节点数

原文:https://www . geesforgeks . org/n 元树的每个节点的子树中的叶节点数/

给定一个 N 元树 ,打印每个节点的子树中的叶节点数。
:

Input:
1
/ \
2 3
/ | \
4 5 6
Output:
The node 1 has 4 leaf nodes
The node 2 has 1 leaf nodes
The node 3 has 3 leaf nodes
The node 4 has 1 leaf nodes
The node 5 has 1 leaf nodes
The node 6 has 1 leaf nodes

逼近:思路是对给定的树进行 DFS 遍历,对于每个节点保留一个数组 leaf【】,以存储其下子树的叶节点数。
现在,当沿树向下循环时,如果发现一个叶节点,将其叶[i]值设置为 1,并向上返回。现在,每次从向上的函数调用返回时,添加它下面的节点的叶节点。
一旦完成 DFS 遍历,我们将获得数组叶[]中叶节点的计数。
以下是上述方法的实施:

C++

// C++ program to print the number of
// leaf nodes of every node
#include
using namespace std;
// Function to insert edges of tree
void insert(int x, int y, vector adjacency[])
{
    adjacency[x].push_back(y);
}
// Function to run DFS on a tree
void dfs(int node, int leaf[], int vis[],
         vector adjacency[])
{
    leaf[node] = 0;
    vis[node] = 1;
    // iterate on all the nodes
    // connected to node
    for (auto it : adjacency[node]) {
        // If not visited
        if (!vis[it]) {
            dfs(it, leaf, vis, adjacency);
            leaf[node] += leaf[it];
        }
    }
    if (!adjacency[node].size())
        leaf[node] = 1;
}
// Function to print number of
// leaf nodes of a node
void printLeaf(int n, int leaf[])
{
    // Function to print leaf nodes
    for (int i = 1; i <= n; i++) {
        cout <<"The node " <             <    }
}
// Driver Code
int main()
{
    // Given N-ary Tree
    /*     1
         /   \
        2     3
            / | \
            4 5 6 */
    int N = 6; // no of nodes
    vector adjacency[N + 1]; // adjacency list for tree
    insert(1, 2, adjacency);
    insert(1, 3, adjacency);
    insert(3, 4, adjacency);
    insert(3, 5, adjacency);
    insert(3, 6, adjacency);
    int leaf[N + 1]; // Store count of leaf in subtree of i
    int vis[N + 1] = { 0 }; // mark nodes visited
    dfs(1, leaf, vis, adjacency);
    printLeaf(N, leaf);
    return 0;
}

Java 语言(一种计算机语言,尤用于创建网站)

// Java program to print the number of
// leaf nodes of every node
import java.util.*;
class GFG
{
static Vector> adjacency = new
       Vector>();
// Function to insert edges of tree
static void insert(int x, int y)
{
    adjacency.get(x).add(y);
}
// Function to run DFS on a tree
static void dfs(int node, int leaf[], int vis[])
{
    leaf[node] = 0;
    vis[node] = 1;
    // iterate on all the nodes
    // connected to node
    for (int i = 0; i     {
        int it = adjacency.get(node).get(i);
        // If not visited
        if (vis[it] == 0)
        {
            dfs(it, leaf, vis);
            leaf[node] += leaf[it];
        }
    }
    if (adjacency.get(node).size() == 0)
        leaf[node] = 1;
}
// Function to print number of
// leaf nodes of a node
static void printLeaf(int n, int leaf[])
{
    // Function to print leaf nodes
    for (int i = 1; i <= n; i++)
    {
        System.out.print( "The node " + i + " has " +
                          leaf[i] + " leaf nodes\n");
    }
}
// Driver Code
public static void main(String args[])
{
    // Given N-ary Tree
    /*     1
        / \
        2     3
            / | \
            4 5 6 */
    int N = 6; // no of nodes
    for(int i = 0; i <= N; i++)
    adjacency.add(new Vector());
    insert(1, 2);
    insert(1, 3);
    insert(3, 4);
    insert(3, 5);
    insert(3, 6);
    // Store count of leaf in subtree of i
    int leaf[] = new int[N + 1];
    // mark nodes visited
    int vis[] = new int[N + 1] ;
    dfs(1, leaf, vis);
    printLeaf(N, leaf);
}
}
// This code is contributed by Arnab Kundu

Python 3

# Python3 program to print the number of
# leaf nodes of every node
adjacency = [[] for i in range(100)]
# Function to insert edges of tree
def insert(x, y):
    adjacency[x].append(y)
# Function to run DFS on a tree
def dfs(node, leaf, vis):
    leaf[node] = 0
    vis[node] = 1
    # iterate on all the nodes
    # connected to node
    for it in adjacency[node]:
        # If not visited
        if (vis[it] == False):
            dfs(it, leaf, vis)
            leaf[node] += leaf[it]
    if (len(adjacency[node]) == 0):
        leaf[node] = 1
# Function to prnumber of
# leaf nodes of a node
def printLeaf(n, leaf):
    # Function to prleaf nodes
    for i in range(1, n + 1):
        print("The node", i, "has", 
               leaf[i], "leaf nodes")
# Driver Code
# Given N-ary Tree
'''
/*     1
    / \
    2     3
        / | \
        4 5 6 '''
N = 6 # no of nodes
# adjacency list for tree
insert(1, 2)
insert(1, 3)
insert(3, 4)
insert(3, 5)
insert(3, 6)
# Store count of leaf in subtree of i
leaf = [0 for i in range(N + 1)]
# mark nodes visited
vis = [0 for i in range(N + 1)]
dfs(1, leaf, vis)
printLeaf(N, leaf)
# This code is contributed by Mohit Kumar

C

// C# program to print the number of
// leaf nodes of every node
using System;
using System.Collections.Generic;
class GFG
{
static List> adjacency = new
       List>();
// Function to insert edges of tree
static void insert(int x, int y)
{
    adjacency[x].Add(y);
}
// Function to run DFS on a tree
static void dfs(int node, int []leaf, int []vis)
{
    leaf[node] = 0;
    vis[node] = 1;
    // iterate on all the nodes
    // connected to node
    for (int i = 0; i     {
        int it = adjacency[node][i];
        // If not visited
        if (vis[it] == 0)
        {
            dfs(it, leaf, vis);
            leaf[node] += leaf[it];
        }
    }
    if (adjacency[node].Count == 0)
        leaf[node] = 1;
}
// Function to print number of
// leaf nodes of a node
static void printLeaf(int n, int []leaf)
{
    // Function to print leaf nodes
    for (int i = 1; i <= n; i++)
    {
        Console.Write( "The node " + i + " has " +
                          leaf[i] + " leaf nodes\n");
    }
}
// Driver Code
public static void Main(String []args)
{
    // Given N-ary Tree
    /*     1
        / \
        2     3
            / | \
            4 5 6 */
    int N = 6; // no of nodes
    for(int i = 0; i <= N; i++)
    adjacency.Add(new List());
    insert(1, 2);
    insert(1, 3);
    insert(3, 4);
    insert(3, 5);
    insert(3, 6);
    // Store count of leaf in subtree of i
    int []leaf = new int[N + 1];
    // mark nodes visited
    int []vis = new int[N + 1] ;
    dfs(1, leaf, vis);
    printLeaf(N, leaf);
}
}
// This code contributed by Rajput-Ji

java 描述语言


Output: 

The node 1 has 4 leaf nodes
The node 2 has 1 leaf nodes
The node 3 has 3 leaf nodes
The node 4 has 1 leaf nodes
The node 5 has 1 leaf nodes
The node 6 has 1 leaf nodes

推荐阅读
  • 本文探讨了如何在给定整数N的情况下,找到两个不同的整数a和b,使得它们的和最大,并且满足特定的数学条件。 ... [详细]
  • PyCharm下载与安装指南
    本文详细介绍如何从官方渠道下载并安装PyCharm集成开发环境(IDE),涵盖Windows、macOS和Linux系统,同时提供详细的安装步骤及配置建议。 ... [详细]
  • Java 中 Writer flush()方法,示例 ... [详细]
  • 技术分享:从动态网站提取站点密钥的解决方案
    本文探讨了如何从动态网站中提取站点密钥,特别是针对验证码(reCAPTCHA)的处理方法。通过结合Selenium和requests库,提供了详细的代码示例和优化建议。 ... [详细]
  • C++实现经典排序算法
    本文详细介绍了七种经典的排序算法及其性能分析。每种算法的平均、最坏和最好情况的时间复杂度、辅助空间需求以及稳定性都被列出,帮助读者全面了解这些排序方法的特点。 ... [详细]
  • 深入理解Tornado模板系统
    本文详细介绍了Tornado框架中模板系统的使用方法。Tornado自带的轻量级、高效且灵活的模板语言位于tornado.template模块,支持嵌入Python代码片段,帮助开发者快速构建动态网页。 ... [详细]
  • 使用 Azure Service Principal 和 Microsoft Graph API 获取 AAD 用户列表
    本文介绍了一段通用代码示例,该代码不仅能够操作 Azure Active Directory (AAD),还可以通过 Azure Service Principal 的授权访问和管理 Azure 订阅资源。Azure 的架构可以分为两个层级:AAD 和 Subscription。 ... [详细]
  • Python自动化处理:从Word文档提取内容并生成带水印的PDF
    本文介绍如何利用Python实现从特定网站下载Word文档,去除水印并添加自定义水印,最终将文档转换为PDF格式。该方法适用于批量处理和自动化需求。 ... [详细]
  • UNP 第9章:主机名与地址转换
    本章探讨了用于在主机名和数值地址之间进行转换的函数,如gethostbyname和gethostbyaddr。此外,还介绍了getservbyname和getservbyport函数,用于在服务器名和端口号之间进行转换。 ... [详细]
  • 扫描线三巨头 hdu1928hdu 1255  hdu 1542 [POJ 1151]
    学习链接:http:blog.csdn.netlwt36articledetails48908031学习扫描线主要学习的是一种扫描的思想,后期可以求解很 ... [详细]
  • 2023年京东Android面试真题解析与经验分享
    本文由一位拥有6年Android开发经验的工程师撰写,详细解析了京东面试中常见的技术问题。涵盖引用传递、Handler机制、ListView优化、多线程控制及ANR处理等核心知识点。 ... [详细]
  • 本题探讨了一种字符串变换方法,旨在判断两个给定的字符串是否可以通过特定的字母替换和位置交换操作相互转换。核心在于找到这些变换中的不变量,从而确定转换的可能性。 ... [详细]
  • 本文详细介绍如何使用Python进行配置文件的读写操作,涵盖常见的配置文件格式(如INI、JSON、TOML和YAML),并提供具体的代码示例。 ... [详细]
  • Java 类成员初始化顺序与数组创建
    本文探讨了Java中类成员的初始化顺序、静态引入、可变参数以及finalize方法的应用。通过具体的代码示例,详细解释了这些概念及其在实际编程中的使用。 ... [详细]
  • 本文介绍了在Windows环境下使用pydoc工具的方法,并详细解释了如何通过命令行和浏览器查看Python内置函数的文档。此外,还提供了关于raw_input和open函数的具体用法和功能说明。 ... [详细]
author-avatar
林姗飘零1999
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有