comments | difficulty | edit_url | rating | source | tags | |||
---|---|---|---|---|---|---|---|---|
true |
困难 |
2085 |
第 423 场周赛 Q3 |
|
给你一个整数数组 nums
。好子序列 的定义是:子序列中任意 两个 连续元素的绝对差 恰好 为 1。
子序列 是指可以通过删除某个数组的部分元素(或不删除)得到的数组,并且不改变剩余元素的顺序。
返回 nums
中所有 可能存在的 好子序列的 元素之和。
因为答案可能非常大,返回结果需要对 109 + 7
取余。
注意,长度为 1 的子序列默认为好子序列。
示例 1:
输入:nums = [1,2,1]
输出:14
解释:
- 好子序列包括:
[1]
,[2]
,[1]
,[1,2]
,[2,1]
,[1,2,1]
。 - 这些子序列的元素之和为 14。
示例 2:
输入:nums = [3,4,5]
输出:40
解释:
- 好子序列包括:
[3]
,[4]
,[5]
,[3,4]
,[4,5]
,[3,4,5]
。 - 这些子序列的元素之和为 40。
提示:
1 <= nums.length <= 105
0 <= nums[i] <= 105
class Solution:
def sumOfGoodSubsequences(self, nums: List[int]) -> int:
mod = 10**9 + 7
f = defaultdict(int)
g = defaultdict(int)
for x in nums:
f[x] += x
g[x] += 1
f[x] += f[x - 1] + g[x - 1] * x
g[x] += g[x - 1]
f[x] += f[x + 1] + g[x + 1] * x
g[x] += g[x + 1]
return sum(f.values()) % mod
class Solution {
public int sumOfGoodSubsequences(int[] nums) {
final int mod = (int) 1e9 + 7;
int mx = 0;
for (int x : nums) {
mx = Math.max(mx, x);
}
long[] f = new long[mx + 1];
long[] g = new long[mx + 1];
for (int x : nums) {
f[x] += x;
g[x] += 1;
if (x > 0) {
f[x] = (f[x] + f[x - 1] + g[x - 1] * x % mod) % mod;
g[x] = (g[x] + g[x - 1]) % mod;
}
if (x + 1 <= mx) {
f[x] = (f[x] + f[x + 1] + g[x + 1] * x % mod) % mod;
g[x] = (g[x] + g[x + 1]) % mod;
}
}
long ans = 0;
for (long x : f) {
ans = (ans + x) % mod;
}
return (int) ans;
}
}
class Solution {
public:
int sumOfGoodSubsequences(vector<int>& nums) {
const int mod = 1e9 + 7;
int mx = ranges::max(nums);
vector<long long> f(mx + 1), g(mx + 1);
for (int x : nums) {
f[x] += x;
g[x] += 1;
if (x > 0) {
f[x] = (f[x] + f[x - 1] + g[x - 1] * x % mod) % mod;
g[x] = (g[x] + g[x - 1]) % mod;
}
if (x + 1 <= mx) {
f[x] = (f[x] + f[x + 1] + g[x + 1] * x % mod) % mod;
g[x] = (g[x] + g[x + 1]) % mod;
}
}
return accumulate(f.begin(), f.end(), 0LL) % mod;
}
};
func sumOfGoodSubsequences(nums []int) (ans int) {
mod := int(1e9 + 7)
mx := slices.Max(nums)
f := make([]int, mx+1)
g := make([]int, mx+1)
for _, x := range nums {
f[x] += x
g[x] += 1
if x > 0 {
f[x] = (f[x] + f[x-1] + g[x-1]*x%mod) % mod
g[x] = (g[x] + g[x-1]) % mod
}
if x+1 <= mx {
f[x] = (f[x] + f[x+1] + g[x+1]*x%mod) % mod
g[x] = (g[x] + g[x+1]) % mod
}
}
for _, x := range f {
ans = (ans + x) % mod
}
return
}
function sumOfGoodSubsequences(nums: number[]): number {
const mod = 10 ** 9 + 7;
const mx = Math.max(...nums);
const f: number[] = Array(mx + 1).fill(0);
const g: number[] = Array(mx + 1).fill(0);
for (const x of nums) {
f[x] += x;
g[x] += 1;
if (x > 0) {
f[x] = (f[x] + f[x - 1] + ((g[x - 1] * x) % mod)) % mod;
g[x] = (g[x] + g[x - 1]) % mod;
}
if (x + 1 <= mx) {
f[x] = (f[x] + f[x + 1] + ((g[x + 1] * x) % mod)) % mod;
g[x] = (g[x] + g[x + 1]) % mod;
}
}
return f.reduce((acc, cur) => (acc + cur) % mod, 0);
}