Offer 驾到,掘友接招!我正在参与2022春招打卡活动,点击查看活动详情。
一、题目描述:
有一个自行车手打算进行一场公路骑行,这条路线总共由 n + 1 个不同海拔的点组成。自行车手从海拔为 0 的点 0 开始骑行。
给你一个长度为 n 的整数数组 gain ,其中 gain[i] 是点 i 和点 i + 1 的 净海拔高度差(0 <= i < n)。请你返回 最高点的海拔 。
示例 1:
输入:gain = [-5,1,5,0,-7] 输出:1 解释:海拔高度依次为 [0,-5,-4,1,1,-6] 。最高海拔为 1 。 示例 2:
输入:gain = [-4,-3,-2,-1,4,3,2] 输出:0 解释:海拔高度依次为 [0,-4,-7,-9,-10,-6,-3,-1] 。最高海拔为 0 。
提示:
n == gain.length 1 <= n <= 100 -100 <= gain[i] <= 100
来源:力扣(LeetCode) 链接:leetcode-cn.com/problems/fi… 著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
二、思路分析:
理解题意:净海拔高度差,看示例可知,是与起点的海拔差距,题目比较简单
具体做法如下:
初始化一个最大值max=0,遍历数组,依次相加,并与max对比,如果结果大于max,替换max值为当前结果,如果max大于当前结构值,不变。
三、AC 代码:
class Solution {
public int largestAltitude(int[] gain) {
int max=0;
int sum=0;
for(int i=0;i<gain.length;i++){
sum += gain[i];
max=Math.max(max,sum);
}
return max;
}
}
四、总结:
掘友们,以上就是今天题解的全部内容了,如果你觉得有帮助的话,解题不易,留下个赞或评论再走吧!谢啦~ 💐