完全二叉树的权值

#include<iostream>
using namespace std;
typedef long long LL;
const int N = 1e5 + 10;
LL a[N];
int main() {
	int n;
	cin >> n;
	for (int i = 1; i <= n; i ++)cin >> a[i];
	LL d = 1;
	LL mx = -1e18;
	LL dp;
	for (int i = 1, k = 1; i <= n; i += k, k *= 2, d++) {
		LL sum = 0;
		for (int j = k; j < k * 2 && j <= n; j ++) {
			sum += a[j];
		}
		if (sum > mx) {
			dp = d;
			mx = sum;
		}

	}
	cout << dp << endl;
}
注意:最后一层可能不全,所以i要先加上k,k在乘2
全部评论

相关推荐

不愿透露姓名的神秘牛友
07-08 10:39
一个证都没&nbsp;我能填什么
程序员小白条:别人有,你为什么没有,还是这个道理,社会就是比较,竞争,淘汰,你要安逸,那么就要做好淘汰的准备
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务