zoukankan      html  css  js  c++  java
  • codevs 1814 最长链

    1814 最长链

     

     时间限制: 1 s
     空间限制: 256000 KB
     题目等级 : 钻石 Diamond
     
     
    题目描述 Description

    现给出一棵N个结点二叉树,问这棵二叉树中最长链的长度为多少,保证了1号结点为二叉树的根。

    输入描述 Input Description

    输入的第1行为包含了一个正整数N,为这棵二叉树的结点数,结点标号由1至N。

    接下来N行,这N行中的第i行包含两个正整数l[i], r[i],表示了结点i的左儿子与右儿子编号。如果l[i]为0,表示结点i没有左儿子,同样地,如果r[i]为0则表示没有右儿子。

    输出描述 Output Description

    输出包括1个正整数,为这棵二叉树的最长链长度。

    样例输入 Sample Input

    5

    2 3

    4 5

    0 6

    0 0

    0 0

    样例输出 Sample Output

    4

    数据范围及提示 Data Size & Hint

    【样例说明】

      4-2-1-3-6为这棵二叉树中的一条最长链。

    【数据规模】

    对于10%的数据,有N≤10;

    对于40%的数据,有N≤100;

    对于50%的数据,有N≤1000;

    对于60%的数据,有N≤10000;

    对于100%的数据,有N≤100000,且保证了树的深度不超过32768。

    【提示】

    关于二叉树:

    二叉树的递归定义:二叉树要么为空,要么由根结点,左子树,右子树组成。左子树和右子树分别是一棵二叉树。

    请注意,有根树和二叉树的三个主要差别:

    1. 树的结点个数至少为1,而二叉树的结点个数可以为0;

    2. 树中结点的最大度数没有限制,而二叉树结点的最大度数为2;

    3. 树的结点无左、右之分,而二叉树的结点有左、右之分。

    关于最长链:

    最长链为这棵二叉树中一条最长的简单路径,即不经过重复结点的一条路径。可以容易证明,二叉树中最长链的起始、结束结点均为叶子结点。

    /*
    一看应该就懂了 
    */
    #include<iostream>
    #include<cstdio>
    #include<cstring>
    #define maxn 100010
    using namespace std;
    int l[maxn],r[maxn],h[maxn],ans;
    void dfs(int x)
    {
        if(!l[x]&&!r[x])
        {
            h[x]=1;
            return;
        }
        if(l[x])dfs(l[x]);
        if(r[x])dfs(r[x]);
        ans=max(ans,h[l[x]]+h[r[x]]);
        h[x]=max(h[l[x]],h[r[x]])+1;
    }
    int main()
    {
        int n,i,j,k;
        scanf("%d",&n);
        for(i=1;i<=n;i++)
        scanf("%d%d",&l[i],&r[i]);
        dfs(1);
        printf("%d
    ",ans);
        return 0;
    }
  • 相关阅读:
    AcWing 157. 树形地铁系统 (hash判断树同构)打卡
    AcWing 156. 矩阵 (哈希二维转一维查询)打卡
    AcWing 144. 最长异或值路径 01字典树打卡
    AcWing 143. 最大异或对 01字典树打卡
    AcWing 142. 前缀统计 字典树打卡
    AcWing 139. 回文子串的最大长度 hash打卡
    AcWing 138. 兔子与兔子 hash打卡
    常用C库函数功能及用法
    编程实现C库函数
    C语言面试题5
  • 原文地址:https://www.cnblogs.com/dingmenghao/p/5741699.html
Copyright © 2011-2022 走看看