2024-1-24
ans
为0,用于记录最大的和值。n
中。n-1
。y
,并将其赋值给变量 t
,用于记录当前位置的和值。i-1
到0。在内层循环中,更新变量 y
为当前位置与左侧位置的高度的较小值,然后将 y
累加到 t
中。y
重新设置为当前位置的高度。i+1
到 n-1
。在内层循环中,更新变量 y
为当前位置与右侧位置的高度的较小值,然后将 y
累加到 t
中。t
,将其与之前记录的最大和值 ans
比较,取其中较大的值作为新的最大和值,并更新变量 ans
。ans
。public long maximumSumOfHeights(List<Integer> maxHeights) {
long ans = 0;
int n = maxHeights.size();
// 遍历每一个位置
for (int i = 0; i < n; ++i) {
int y = maxHeights.get(i);
long t = y;
// 向左遍历,计算左边最小高度的和
for (int j = i - 1; j >= 0; --j) {
y = Math.min(y, maxHeights.get(j));
t += y;
}
// 重置y为当前位置的高度
y = maxHeights.get(i);
// 向右遍历,计算右边最小高度的和
for (int j = i + 1; j < n; ++j) {
y = Math.min(y, maxHeights.get(j));
t += y;
}
// 更新最大和
ans = Math.max(ans, t);
}
return ans;
}
通过两个内层循环分别计算了每个位置的左侧和右侧高度最小值的和,然后将二者相加得到当前位置的和值 t
,并与之前记录的最大和值 ans
进行比较和更新。最终返回最大和值 ans
。