Leetcode-3427变长子数组求和

依旧前缀和,3427. 变长子数组求和

是一个套路,数组有len个元素,设置一个len+1个元素的数组cnt,cnt[0] = 0,cnt[i+1] = cnt[i]+nums[i],避开了left为0时需要讨论的情况。left = x, right = y,最后结果 = cnt[y+1] - left[x],可以画个图理解下更直观。

C++代码

cpp 复制代码
class Solution {
public:
    int subarraySum(vector<int>& nums) {
        int len =nums.size();
        vector<int> cnt;
        cnt.resize(len+1);
        int ans = 0;
        for(int i = 0; i <len ;i++){
            cnt[i+1] = cnt[i]+nums[i];
        }
        for(int i = 0; i<len;i++){
            ans+=cnt[i+1]-cnt[max(0,i-nums[i])];
        }
        return ans;
    }
};
相关推荐
黎雁·泠崖1 天前
栈与队列实战通关:3道经典OJ题深度解析
c语言·数据结构·leetcode
AlenTech1 天前
160. 相交链表 - 力扣(LeetCode)
数据结构·leetcode·链表
sin_hielo1 天前
leetcode 1161(BFS)
数据结构·算法·leetcode
iAkuya1 天前
(leetcode)力扣100 34合并K个升序链表(排序,分治合并,优先队列)
算法·leetcode·链表
放荡不羁的野指针1 天前
leetcode150题-字符串
数据结构·算法·leetcode
橘颂TA1 天前
【剑斩OFFER】算法的暴力美学——存在重复元素Ⅱ
算法·leetcode·哈希算法·散列表·结构与算法
cg50171 天前
力扣数据库——组合两个表
sql·算法·leetcode
2501_941798731 天前
面向微服务分布式事务补偿与最终一致性的互联网系统高可用设计与多语言工程实践分享
leetcode·模拟退火算法
ada7_1 天前
LeetCode(python)22.括号生成
开发语言·数据结构·python·算法·leetcode·职场和发展
YuTaoShao1 天前
【LeetCode 每日一题】1161. 最大层内元素和——BFS
算法·leetcode·宽度优先