首页 > 其他分享 >891. 子序列宽度之和 ----- 贡献值法

891. 子序列宽度之和 ----- 贡献值法

时间:2022-11-18 12:13:10浏览次数:51  
标签:891 值法 nums pow2 int ----- ans 序列 MOD

一个序列的 宽度 定义为该序列中最大元素和最小元素的差值。

给你一个整数数组 nums ,返回 nums 的所有非空 子序列 的 宽度之和 。由于答案可能非常大,请返回对 109 + 7 取余 后的结果。

子序列 定义为从一个数组里删除一些(或者不删除)元素,但不改变剩下元素的顺序得到的数组。例如,[3,6,2,7] 就是数组 [0,3,1,6,2,2,7] 的一个子序列。

 

示例 1:

输入:nums = [2,1,3]
输出:6
解释:子序列为 [1], [2], [3], [2,1], [2,3], [1,3], [2,1,3] 。
相应的宽度是 0, 0, 0, 1, 1, 2, 2 。
宽度之和是 6 。
示例 2:

输入:nums = [2]
输出:0
 

提示:

1 <= nums.length <= 105
1 <= nums[i] <= 105

来源:力扣(LeetCode)
链接:https://leetcode.cn/problems/sum-of-subsequence-widths
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

class Solution {
    const int MOD = 1e9 + 7;
public:
    int sumSubseqWidths(vector<int> &nums) {
        sort(nums.begin(), nums.end());
        int n = nums.size(), pow2[n];
        pow2[0] = 1;
        for (int i = 1; i < n; ++i)
            pow2[i] = pow2[i - 1] * 2 % MOD; // 预处理 2 的幂次
        long ans = 0L;
        for (int i = 0; i < n; ++i)
            ans += long(pow2[i] - pow2[n - 1 - i]) * nums[i]; // 在题目的数据范围下,这不会溢出
        return (ans % MOD + MOD) % MOD; // 注意上面有减法,ans 可能为负数
    }
};

【C++】数学(乘法)

  • 假如数组:[2,1,3],因为子序列顺序不会对结果产生影响
  • 比如它的子序列[1], [2], [3], [2,1], [2,3], [1,3], [2,1,3] 跟[1,2,3]的子序列[1],[2],[3],[1,2],[1,3],[2,3],[1,2,3]最终结果是一样的
  • 所以我们按照递增排序后讨论,这样每个元素都比它左边大或相等(作为最大值),比它右边小(作为最小值)
  • 那么我们只需要讨论每个元素左右的贡献值,我们不妨拿数字2作为例子,那么它作为最大值贡献了2^i次(i=1,排序后),作为最小值贡献了2^(n-i-1)次,可以用数学归纳证明(这里略),注:贡献都包含本身统计,结果相减没影响
  • 结果就是每个数贡献值相加sum(2^i-2^(n-i-1))*nums[i])

标签:891,值法,nums,pow2,int,-----,ans,序列,MOD
From: https://www.cnblogs.com/slowlydance2me/p/16902771.html

相关文章

  • DTOJ-2022-11-10-测试-题解
    题目链接ABCA这个套路已经出现了很多次了就是两条线之间的网格图路径数,做法呢就是容斥题意求满足以下条件的\(n\timesm\)的矩阵的个数对\(10^9+7\)取模对于......
  • router-link 路由参数
    1、路由信息对象:通过this.$route可获取组件的配置路由的对象,只读对象。  2、路由操作对象:通过this.$router可获取路由对象,也就是VueRouter,只写对象。 3、路由......
  • 2022-11-17 纳斯达克指数,5分钟三段式上涨回补跳空缺口。
    30分钟中枢下  5分钟三段式上涨,回补向下跳空缺口 ......
  • React源码中的dom-diff
    这一章就来讲讲React在协调阶段的beginWork里面主要做的事情--domdiff。本文主要讲的是React17.0.2版本的diff,在此我也画了一个简单的流程图:reconcileChildrendomd......
  • 四、Redis企业实战 - 优惠劵秒杀
    在喧嚣之外孤单戒掉廉价的浪漫全局唯一ID生成每个店铺都可以发布优惠券,当用户抢购时,就会生成订单并保存到tb_voucher_order这张表中。而订单表如果使用数据库自增I......
  • Python-统计执行时间
    方法一:importdatetimeimporttimestarttime=datetime.datetime.now()print(starttime.strftime("%Y-%m-%d%H:%M:%S"))time.sleep(2)endtime=datetime.datet......
  • [C++]-日志记录库SPDLog简介[通俗易懂]
    文章目录spdlog库日志记录槽sink日志记录器logger输出格式pattern对齐方式截断字符串格式化fmtFormatSpecificationspdlog使用异常处理logger基......
  • Python - typing 模块
    typing模块的作用类型检查,防止运行时出现参数和返回值类型不符合。作为开发文档附加说明,方便使用者调用时传入和返回参数类型。该模块加入后并不会影响程序的运行,不会......
  • 0-1背包问题小结
    使用二维数组的情况先直接上代码。#include<iostream>#include<vector>//bits/stdc++.h文件在实际开发中不要使用//在VScode中似乎已经限制了bits/c++.h的使用。//#......
  • letcode算法--21.螺旋矩阵 II
    给你一个正整数 n ,生成一个包含 1 到 n2 所有元素,且元素按顺时针顺序螺旋排列的 nxn 正方形矩阵 matrix 。示例1:输入:n=3输出:[[1,2,3],[8,9,4],[7,6,5]]......