carloscn / structstudy

Leetcode daily trainning by using C/C++/RUST programming.
4 stars 1 forks source link

leetcode1732:找到最高海拔(find-the-highest-altitude) #272

Open carloscn opened 1 year ago

carloscn commented 1 year ago

问题描述

有一个自行车手打算进行一场公路骑行,这条路线总共由 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) 链接:https://leetcode.cn/problems/find-the-highest-altitude

carloscn commented 1 year ago

问题分析

pub fn largest_altitude(gain: Vec<i32>) -> i32
{
    if gain.len() < 1 {
        return 0;
    }

    let mut r_v:Vec<i32> = vec![0];

    for i in 0..gain.len() {
        let e = r_v[i] + gain[i];
        r_v.push(e);
    }

    return r_v.iter().fold(i32::MIN, |count, x| count.max(*x));
}
carloscn commented 1 year ago

code

https://review.gerrithub.io/c/carloscn/structstudy/+/556587 https://github.com/carloscn/structstudy/commit/1d415f408f33bc1ddeae4ce26102dcbaf75dd4a8