## 腾讯面试题-快乐树
### 题目描述
整个公司的人员结构可以看作是一棵标准的多叉树。树的头节点是公司唯一的老板,除老板外,每个员工都有唯一的直接上级,叶节点是没有任何下属的基层员工,除基层员工外,每个员工都有一个或多个直接下级,另外每个员工都有一个快乐值。
这个公司现在要办 party,你可以决定哪些员工来,哪些员工不来。但是要遵循如下的原则:
1.如果某个员工来了,那么这个员工的所有直接下级都不能来。
2.派对的整体快乐值是所有到场员工快乐值的累加。
3.你的目标是让派对的整体快乐值尽量大。
给定一棵多叉树,请输出派对的最大快乐值。
### 代码实现
```cpp
#include <iostream>
#include <vector>
#include <memory>
using namespace std;
struct HappyTree {
typedef shared_ptr<HappyTree> ptr;
int happy;
vector<HappyTree::ptr> datas;
HappyTree(int h) : happy(h) {}
~HappyTree() { datas.clear(); }
void addEmploee(HappyTree::ptr e)
{
datas.push_back(e);
}
};
int maxHappy(HappyTree* root, bool canBeyondRoot)
{
int happyNoRoot = 0;
for (auto x : root->datas) {
happyNoRoot += maxHappy(x.get(), true);
}
int happyWithRoot = 0;
if (canBeyondRoot) {
happyWithRoot += root->happy;
for (auto x : root->datas) {
happyWithRoot += maxHappy(x.get(), false);
}
}
return max(happyNoRoot, happyWithRoot);
}
int main(int argc, char** argv)
{
HappyTree::ptr h1 = make_shared<HappyTree>(1);
HappyTree::ptr h2 = make_shared<HappyTree>(2);
HappyTree::ptr h3 = make_shared<HappyTree>(3);
HappyTree::ptr h4 = make_shared<HappyTree>(4);
HappyTree::ptr h5 = make_shared<HappyTree>(5);
HappyTree::ptr h6 = make_shared<HappyTree>(6);
HappyTree::ptr h7 = make_shared<HappyTree>(7);
h2->addEmploee(h5);
h3->addEmploee(h6);
h4->addEmploee(h7);
h1->addEmploee(h2);
h1->addEmploee(h3);
h1->addEmploee(h4);
int happy = maxHappy(h1.get(), true);
cout << "happy=" << happy << endl;
return 0;
}
```
### 进程和线程
进程是系统进行资源分配和调度的基本独立单位
线程是进程的一个实体,是CPU调度和分派的基本单位
多进程和多线程在执行过程中都需要一定的同步机制进行同步
系统开销:进程在创建和切换的开销远大线程,但进程相比线程更健壮(因为进程之间相互独立)
- 空白目录
- 算法
- 排序
- 冒泡排序
- 选择排序
- 插入排序
- 归并排序
- 快速排序
- 计数排序
- 桶排序
- 基数排序
- 希尔排序
- 堆排序
- 二分查找
- 最小堆
- 最小索引堆
- 平衡二叉树(AVL tree)
- bitmap位图
- 布隆过滤器
- hashmap
- topK
- 跳表
- LRU Cache
- kmp
- 最小堆和堆排序
- 最短路径
- C++
- 运行时类型判断RTTI
- C++反射
- 手动实现智能指针
- 序列化实现
- rpc实现
- std::forward
- 函数指针的妙用
- C/C++
- std::function
- 同步队列
- 线程池实现
- std::promise
- 深入理解虚函数
- extern "C" 关键字讲解
- 大端小端的区别
- 简历
- 简历1
- redis
- 数据结构和对象
- sds
- list
- zskiplist
- 腾讯云redis面试题总结
- redis集群部署
- LeetCode
- 目标
- go基础
- 算法快速入门
- 数据结构篇
- 二叉树
- 链表
- 栈和队列
- 二进制
- 基础算法篇
- 二分搜索
- 排序算法
- 动态规划
- 算法思维
- 递归思维
- 滑动窗口思想
- 二叉搜索树
- 回溯法
- 其他
- 剑指offer
- 笔记
- git代理加速
- Linux
- vim大法
- vscode远程不能跳转
- cmake
- 设计模式
- 单例模式
- 简单工厂模式
- 外观模式
- 适配器模式
- 工厂方法模式
- 抽象工厂模式
- 生成器模式
- 原型模式
- 中介者模式
- 观察者模式
- 访问者模式
- 命令模式
- 网络编程
- epoll reactor模式
- linux timerfd系列函数总结
- IO
- mapreduce
- 反射器
- leo通信库
- Mutex
- Condition
- thread
- raft
- 协程
- hook
- 定时器
- 别人的面试经验
- 面试题
- vector崩溃问题
- JAVA
- Linux java环境配置
- ucore
- lab1
- FreeNOS
- leveldb
- 刷题笔记
- 回文串
- 前缀树
- 字符串查找
- 查找两个字符串a,b中的最长公共子串
- 动态规划
- golang
- 顺序循环打印实现
- 数据结构
- rpc运用
- python
- 单例
- 深拷贝浅拷贝
- 链表
- python基础题
- mysql
- 事务
- Linux
- 共享内存
- 刷题记录
- 贪心算法
- 动态规划
- 面试
- 腾讯C++面试
- 微众面试JD
- 迅雷网络面试
- 学习网址
- rabbitMq
