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

简介: 比如如下的一棵树,红框标示的有两个符合要求的结构,答案就是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;
}
相关文章
|
算法
史上最牛二分查找,不服来战
史上最牛二分查找,不服来战
99 0
|
算法 C++ Python
【每日算法Day 107】面试必考:良心推荐,一题三解,不看后悔一辈子
【每日算法Day 107】面试必考:良心推荐,一题三解,不看后悔一辈子
135 0
|
算法
代码随想录算法训练营第四天 | 链表 + 每日一题
代码随想录算法训练营第四天 | 链表 + 每日一题
119 0
|
算法
【网易算法笔试】树上摘樱桃
有一棵二叉树,树上的叶子节点定义为“樱桃”。现在需要找出树上有多少个满足如下子结构的“樱桃”串,即一串上刚好有两颗“樱桃”。
229 0
【网易算法笔试】树上摘樱桃
|
SQL 存储 缓存
奇安信校招面试题来啦,兄弟们赶紧收藏进大厂!!!
奇安信校招面试题来啦,兄弟们赶紧收藏进大厂!!!
415 0
奇安信校招面试题来啦,兄弟们赶紧收藏进大厂!!!
|
算法 开发者
算法笔试模拟题精解之“朋友一生一起走”
根据题意可以得出,在不考虑数字范围的情况下,相加等于 k 的数总共有 k/2 对(如果 k 为偶数,应为 k/2-1 对,此处以 k/2 为例)。也就是说,如果 n 的值大于 k 的值,那么 k 的所有数对都符合条件,即 1-n 中一共有 k/2 对好朋友。
算法笔试模拟题精解之“朋友一生一起走”
|
人工智能 算法 BI
算法笔试模拟题精解之“期末考试”
根据题意,需要计算被抄的期望人数。那么首先要计算每个人被抄袭的概率。
算法笔试模拟题精解之“期末考试”
|
人工智能 算法 开发者
算法笔试模拟题精解之“连绵的群山”
可以将山化分为几个小连续区间,每个区间保证越来越高,并且保证每个区间尽可能的长。除第一个和最后一个区间,中间的其余区间,有移除可能的是每个区间的最小值和最大值,第一个区间有移除可能的是最小值,最后一个区间有移除可能的是最大值。这样才能找出最长的山的区间。
算法笔试模拟题精解之“连绵的群山”
|
存储 人工智能 算法
算法笔试模拟题精解之“过吊桥”
根据题意,要知道B同学还能在桥的一头逗留的时间,需要先求出什么时候有连续的两块木板坏掉,或者第一块或者最后一块木板坏掉。
算法笔试模拟题精解之“过吊桥”