2019-F(完全二叉树的权值)

#include <bits/stdc++.h>
using namespace std;
int main(){
    //由于确定是完全二叉树,所以直接按照层进行枚举即可
    long long  n,maxnum = -3500000000ll,maxlayer,cnt =0,flag=0;
    cin>>n;
    for(int layer =0;;layer++){//枚举每一层,从第1层开始进行枚举,层数是layer+1 
        long long sum =0,a;
        for(int i=0;i<(1<<layer);i++)//相当于2的layer次方
        {
        cin>> a;//将读入和运算放在一起,减少时间复杂度
        sum +=a;
        if(++cnt >=n){
            flag = 1;
            break;//所有的元素都读完,则跳出 (最后一层)
        } 
        } 
        if(sum>maxnum)//maxnum一开始取最小值
        {
            maxnum = sum ,maxlayer = layer+1;
        }
        if(flag) break;
    } 
    cout<<maxlayer;
    return 0;
}

 

posted @ 2021-03-04 22:00  zmachine  阅读(173)  评论(0编辑  收藏  举报