力扣-1508 子数组和排序后的区间和

   日期:2020-12-20     浏览:104    评论:0    
核心提示:@[TOC]力扣-1508 子数组和排序后的区间和题目描述给你一个数组 nums ,它包含 n 个正整数。你需要计算所有非空连续子数组的和,并将它们按升序排序,得到一个新的包含 n * (n + 1) / 2 个数字的数组。请你返回在新数组中下标为 left 到 right (下标从 1 开始)的所有数字和(包括左右端点)。由于答案可能很大,请你将它对 10^9 + 7 取模后返回。示例输入:nums = [1,2,3,4], n = 4, left = 1, right = 5输出:13解释

@[TOC]力扣-1508 子数组和排序后的区间和

题目描述

给你一个数组 nums ,它包含 n 个正整数。你需要计算所有非空连续子数组的和,并将它们按升序排序,得到一个新的包含 n * (n + 1) / 2 个数字的数组。

请你返回在新数组中下标为 left 到 right (下标从 1 开始)的所有数字和(包括左右端点)。由于答案可能很大,请你将它对 10^9 + 7 取模后返回。

示例

输入:nums = [1,2,3,4], n = 4, left = 1, right = 5
输出:13
解释:所有的子数组和为 1, 3, 6, 10, 2, 5, 9, 3, 7, 4 。将它们升序排序后,我们得到新的数组 [1, 2, 3, 3, 4, 5, 6, 7, 9, 10] 。下标从 le = 1 到 ri = 5 的和为 1 + 2 + 3 + 3 + 4 = 13 。

这里我解释一下,为什么所有的子数组和为什么是1, 3, 6, 10, 2, 5, 9, 3, 7, 4,
题目说明了。需要计算的是非空连续子数组的和,因此
前四个,1,3,6,10为数组{1},{1,2},{1,2,3},{1,2,3,4}
接着三个,2,5,9为数组{2},{2,3},{2,3,4}
接着后面两个,3,7为数组{3},{3,4}
最后一个就是它本身{4}

源代码

class Solution {
public:
    int rangeSum(vector<int>& nums, int n, int left, int right) {
        if(nums.empty()) return 0;   //如果传递的容器数组为空,则直接返回0
        const int MODULO = 1000000007;
        vector<int> num;   //定义一个新的容器
        int count=0;
        for(int i=0;i<n;i++) //上面的文字解释
        {
            count=0;
            for(int k=i;k<n;k++)
            {
                count+=nums[k];
                num.push_back(count);
            }
        }
        sort(num.begin(),num.end());   //将num按升序排序
        int sum=0;
        for(int i=left-1;i<right;i++) sum=(sum+num[i])%MODULO;
        //注意这里一定是sum=(sum+num[i])%MODULO,不能写成sum+=num[i]%MODULO,会造成溢出的情况
        return sum;
    }
};

 
打赏
 本文转载自:网络 
所有权利归属于原作者,如文章来源标示错误或侵犯了您的权利请联系微信13520258486
更多>最近资讯中心
更多>最新资讯中心
0相关评论

推荐图文
推荐资讯中心
点击排行
最新信息
新手指南
采购商服务
供应商服务
交易安全
关注我们
手机网站:
新浪微博:
微信关注:

13520258486

周一至周五 9:00-18:00
(其他时间联系在线客服)

24小时在线客服