1. 程式人生 > 其它 >LeetCode-2049 統計最高分的結點數

LeetCode-2049 統計最高分的結點數

來源:力扣(LeetCode)

連結:https://leetcode-cn.com/problems/count-nodes-with-the-highest-score

題目描述

給你一棵根節點為 0 的 二叉樹 ,它總共有 n 個節點,節點編號為 0 到 n - 1 。同時給你一個下標從 0 開始的整數陣列 parents 表示這棵樹,其中 parents[i] 是節點 i 的父節點。由於節點 0 是根,所以 parents[0] == -1 。

 

一個子樹的 大小 為這個子樹內節點的數目。每個節點都有一個與之關聯的 分數 。求出某個節點分數的方法是,將這個節點和與它相連的邊全部 刪除 ,剩餘部分是若干個 非空 子樹,這個節點的 分數 為所有這些子樹 大小的乘積 。

 

請你返回有 最高得分 節點的 數目 。

 

 

 

示例 1:

 

 

 

 

 

輸入:parents = [-1,2,0,2,0]

輸出:3

解釋:

- 節點 0 的分數為:3 * 1 = 3

- 節點 1 的分數為:4 = 4

- 節點 2 的分數為:1 * 1 * 2 = 2

- 節點 3 的分數為:4 = 4

- 節點 4 的分數為:4 = 4

最高得分為 4 ,有三個節點得分為 4 (分別是節點 1,3 和 4 )。

 

示例 2:

 

 

 

 

 

輸入:parents = [-1,2,0]

輸出:2

解釋:

- 節點 0 的分數為:2 = 2

- 節點 1 的分數為:2 = 2

- 節點 2 的分數為:1 * 1 = 1

最高分數為 2 ,有兩個節點分數為 2 (分別為節點 0 和 1 )。

 

 

提示:

 

n == parents.length

2 <= n <= 105

parents[0] == -1

對於 i != 0 ,有 0 <= parents[i] <= n - 1

parents 表示一棵二叉樹。

 

解題思路

首先parant陣列儲存形式對於數來說不直觀,很難進行操作,所以遍歷parant陣列,利用鄰接連結串列建立一顆二叉樹。然後使用二叉樹的後續遍歷,分別將左右子樹和分數全求出來,進行比較和計數,需要注意int相乘可能會越界,需要使用long。

程式碼展示

 

class Solution {
public:
    vector<vector<int>> mvviTree;
    long long miMax;
    int miCount;
    void dfs(int root, int &count)
    {
        int iCount = 0;
        long long iCount1 = 1;
        count = 1;
        for(auto iter:mvviTree[root])
        {
            dfs(iter, iCount);
            count += iCount;
            iCount1 *= iCount;
        }
        if(root)
            iCount1 *= (mvviTree.size() - count);
        if(iCount1 > miMax)
        {
            miMax = iCount1;
            miCount = 1;
        }
        else if(iCount1 == miMax)
        {
            miCount++;
        }
    }
    int countHighestScoreNodes(vector<int>& parents) {
        int n = parents.size();
        miCount = 0;
        miMax = 0;
        mvviTree.resize(n, vector<int>());
        int iCount = 0;
        for(int i = 1; i < n; i++)
        {
            mvviTree[parents[i]].push_back(i);
        }
        dfs(0, iCount);
        return miCount;

    }
};

 

 

 

執行結果