力扣1732. 找到最高海拔(前缀和)

Problem: 1732. 找到最高海拔

题目描述

在这里插入图片描述在这里插入图片描述

思路及解法

1.求取数组gain的大小 n n n;
2.定义一个大小为 n + 1 n + 1 n+1的数组preSum;
3.先求取前 n n n个元素的前缀和,再最后单独处理preSum[n];其中preSum[n] = preSum[n - 1] + gain[n - 1];
4.求取处preSum中的最大元素;

复杂度

时间复杂度:

O ( n ) O(n) O(n)

空间复杂度:

O ( n ) O(n) O(n)

Code

class Solution {
   
public:
    /**
     * Prefix sum
     * 
     * @param gain Given array
     * @return int
     */
    int largestAltitude(vector<int>& gain) {
   
        int n = gain.size();
        vector<int> preSum(n + 1);
        int curSum = 0;
        for (int i = 0; i < n; ++i) {
   
            preSum[i] = curSum;
            curSum += gain[i];
        }
        preSum[n] = preSum[n - 1] + gain[n - 1];
        int maxRes = INT_MIN;
        for (int i = 0; i < n + 1; ++i) {
   
            maxRes = max(maxRes, preSum[i]);
        }
        return maxRes;
    }
};

相关推荐

  1. 173. 二叉搜索树迭代器

    2024-02-16 09:04:01       34 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-02-16 09:04:01       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-02-16 09:04:01       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-02-16 09:04:01       18 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-02-16 09:04:01       20 阅读

热门阅读

  1. PMP考试之20240216

    2024-02-16 09:04:01       28 阅读
  2. RISC-V和ARM

    2024-02-16 09:04:01       35 阅读
  3. Python数据科学工具大全

    2024-02-16 09:04:01       29 阅读
  4. nodejs和npm和vite

    2024-02-16 09:04:01       30 阅读
  5. C# 随机打乱数组

    2024-02-16 09:04:01       31 阅读
  6. 五个编程原则:Rob Pike‘s 5 Rules of Programming

    2024-02-16 09:04:01       29 阅读
  7. Codeforces Round 925 (Div. 3)

    2024-02-16 09:04:01       36 阅读
  8. Linux常用指令总结

    2024-02-16 09:04:01       30 阅读