[题解] Tree V

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

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

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

实际上,我们可以利用上述方法来对这棵树进行Dfs搜索,并且按照搜索顺序记录Dfs序的编号,并对应到所给的Dfs序数组上,然后计算加密后的答案即可。

时间复杂度,空间复杂度

参考代码:

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

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

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

相关推荐

暴走萝莉莉:这是社招场吧,作为HR说个实话:这个维护关系的意思是要有政府资源,在曾经的工作中通过人脉资源拿下过大订单的意思。这个有相关管理经验,意思也是真的要有同岗位经验。应酬什么的对于业务成交来说就算不乐意也是常态,就是要求说话好听情商高,酒量好。
点赞 评论 收藏
分享
整顿职场的柯基很威猛:这种不可怕,最可怕的是夹在一帮名校里的二本选手,人家才是最稳的。
点赞 评论 收藏
分享
评论
点赞
收藏
分享
牛客网
牛客企业服务