【网易算法笔试】树上摘樱桃

简介: 比如如下的一棵树,红框标示的有两个符合要求的结构,答案就是2:

题目

有一棵二叉树,树上的叶子节点定义为“樱桃”。现在需要找出树上有多少个满足如下子结构的“樱桃”串,即一串上刚好有两颗“樱桃”。

image.png

比如如下的一棵树,红框标示的有两个符合要求的结构,答案就是2:

image.png

又比如下面的这颗树,没有任何符合要求的子结构,则答案是0:

image.png

输入描述:

第一行两个正整数m, n,空格分开,分别代表总共有树上有多少个节点,和树上有多少条边,2<=m<=100, 1<=n<=100。下面有n行,每行为3个部分,用空格分割,第一个数字为某非叶子节点的id, 第二个为该边为left还是right,第三个为子节点的id。

注意:节点id彼此不会重复,id 1为根节点。


输出描述:

一个整数,标示符合要求的子结构的数量

输入样例:

10 9
1 left 2
1 right 3
2 left 4
2 right 5
3 right 6
6 left 7
6 right 8
8 left 9
8 right 10

输出样例:2


思路

(1)首先建树,注意该题的输入输出格式,需要根据左边还是右边,确定将child被当前节点id的左指针,还是右指针指向。


(2)符合要求的樱桃串(题目中的框框内)的判断,应该是!root->left->left && !root->left->right && !root->right->left && !root->right->right,该节点的“后代”中只有左孩子和右孩子这两个节点了。


代码

#include<iostream>
#include<vector>
#include<string>
using namespace std;
// 定义节点类
class Node{
public:
    Node *left = NULL;
    Node *right = NULL;
};
int Numfun(Node* root){
    if(!root) return 0;
    if(!root->left) return Numfun(root->right);
    if(!root->right) return Numfun(root->left);
    //关键判断
    if(!root->left->left && !root->left->right 
      && !root->right->left && !root->right->right) return 1;
    return Numfun(root->left) + Numfun(root->right);
}
int main(){
    int m, n;
    cin >> m >> n;
    //用vector里的index表示id,因为id从1开始,所以size为m+1
    vector<Node*> a(m+1);
    for(int i = 1; i < m+1; i++){
        a[i] = new Node();
    }
    for(int i = 0; i < n; i++){
        int id;
        cin >> id;
        string position;
        cin >> position;
        int child;
        cin >> child;
        if(position[0] == 'l'){
            a[id]->left = a[child];
        }
        else{
            a[id]->right = a[child];
        }
    }
    cout << Numfun(a[1]);
    return 0;
}
相关文章
|
9月前
|
Windows
孤独的树(牛客月赛)
孤独的树(牛客月赛)
48 0
|
算法 Go
牛客寒假算法集训营 2 感想
【【题目讲解】2023牛客寒假算法基础集训营2】
104 0
牛客寒假算法集训营 2 感想
|
算法
史上最牛二分查找,不服来战
史上最牛二分查找,不服来战
102 0
|
算法 程序员
【算法集训 | 暑期刷题营】8.2题---暴力递归之深搜
【算法集训 | 暑期刷题营】8.2题---暴力递归之深搜
【算法集训 | 暑期刷题营】8.2题---暴力递归之深搜
|
算法 程序员
【算法集训暑期刷题营】7.28题---双指针
【算法集训暑期刷题营】7.28题---双指针
【算法集训暑期刷题营】7.28题---双指针
|
机器学习/深度学习 人工智能 算法
牛客寒假算法基础集训营1 思考+题解
众所周知,2022年是四年一度的世界杯年,那么当然要整点足球题。本题需要你模拟一次点球大战。 假设对战双方为A和B,则点球大战中双方会按照ABABABABAB方式来罚点球,即两队交替罚点球、各罚五次、A队先罚。点球有罚进和罚不进两种结果,罚中的一方加一分。
107 0
|
算法
【网易算法笔试】树上摘樱桃
有一棵二叉树,树上的叶子节点定义为“樱桃”。现在需要找出树上有多少个满足如下子结构的“樱桃”串,即一串上刚好有两颗“樱桃”。
237 0
【网易算法笔试】树上摘樱桃
|
搜索推荐 算法 Java
阿里四面,居然栽在一道排序算法上
大家好,我是指北君。 前两天有童鞋发消息给指北君哭诉阿里四面挂了,据了解,面试过程中该童鞋表现得很不错,所以最后面试官出了道简单题"912. 排序数组"放放水,但指定使用归并排序算法,但该读者因为细节问题运行case始终过不了,最终收到感谢信。
阿里四面,居然栽在一道排序算法上
|
SQL 存储 缓存
奇安信校招面试题来啦,兄弟们赶紧收藏进大厂!!!
奇安信校招面试题来啦,兄弟们赶紧收藏进大厂!!!
421 0
奇安信校招面试题来啦,兄弟们赶紧收藏进大厂!!!
|
算法 开发者
算法笔试模拟题精解之“朋友一生一起走”
根据题意可以得出,在不考虑数字范围的情况下,相加等于 k 的数总共有 k/2 对(如果 k 为偶数,应为 k/2-1 对,此处以 k/2 为例)。也就是说,如果 n 的值大于 k 的值,那么 k 的所有数对都符合条件,即 1-n 中一共有 k/2 对好朋友。
算法笔试模拟题精解之“朋友一生一起走”