[题解] Tree I

考察点:完全二叉树的含义,Bfs序列遍历顺序

需要理解完全二叉树的含义:即每个结点的子结点之多有两个子结点。

不妨我们先考虑最简单的一种情况,即结点编号按照一棵“标准”完全二叉树给出,即结点的两个子结点分别为,根据这棵树,我们可以非常容易的用一次Dfs来“发掘”整棵树的构造。

实际上,上述方法的结点编号即为所给出的Bfs遍历数组的下标(相当于是下标到结点编号的一个映射关系)。

因此,依次计算出每个下标在Bfs序中的位置,然后计算加密后的答案即可。

时间复杂度,空间复杂度

参考代码:

class Solution {
public:
    int n, d[100010];
    long long ans = 0;

    inline void dfs(int x) {
        if ((x << 1) <= n) {
            dfs(x << 1);
            ans += d[x] ^ d[x << 1];
        }
        if ((x << 1 | 1) <= n) {
            dfs(x << 1 | 1);
            ans += d[x] ^ d[x << 1 | 1];
        }
    }

    long long tree1(vector<int>& a) {
        n = a.size();
        for (int i = 0; i < n; ++i) {
            d[i + 1] = a[i];
        }
        dfs(1);
        return ans;
    }
};
全部评论

相关推荐

10-09 22:05
666 C++
找到工作就狠狠玩CSGO:报联合国演讲,报电子烟设计与制造
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
10-12 10:48
已编辑
秋招之苟:邻居家老哥19届双2硕大厂开发offer拿遍了,前几天向他请教秋招,他给我看他当年的简历,0实习实验室项目技术栈跟开发基本不沾边😂,我跟他说这个放在现在中厂简历都过不了
点赞 评论 收藏
分享
头像
11-27 14:28
长沙理工大学
刷算法真的是提升代码能力最快的方法吗?&nbsp;刷算法真的是提升代码能力最快的方法吗?
牛牛不会牛泪:看你想提升什么,代码能力太宽泛了,是想提升算法能力还是工程能力? 工程能力做项目找实习,算法也分数据结构算法题和深度学习之类算法
点赞 评论 收藏
分享
评论
点赞
收藏
分享
牛客网
牛客企业服务