2913. 子数组不同元素数目的平方和 I
题目描述
给你一个下标从 0 开始的整数数组 nums 。
定义 nums 一个子数组的 不同计数 值如下:
- 令 
nums[i..j]表示nums中所有下标在i到j范围内的元素构成的子数组(满足0 <= i <= j < nums.length),那么我们称子数组nums[i..j]中不同值的数目为nums[i..j]的不同计数。 
请你返回 nums 中所有子数组的 不同计数 的 平方 和。
由于答案可能会很大,请你将它对 109 + 7 取余 后返回。
子数组指的是一个数组里面一段连续 非空 的元素序列。
示例 1:
输入:nums = [1,2,1] 输出:15 解释:六个子数组分别为: [1]: 1 个互不相同的元素。 [2]: 1 个互不相同的元素。 [1]: 1 个互不相同的元素。 [1,2]: 2 个互不相同的元素。 [2,1]: 2 个互不相同的元素。 [1,2,1]: 2 个互不相同的元素。 所有不同计数的平方和为 12 + 12 + 12 + 22 + 22 + 22 = 15 。
示例 2:
输入:nums = [2,2] 输出:3 解释:三个子数组分别为: [2]: 1 个互不相同的元素。 [2]: 1 个互不相同的元素。 [2,2]: 1 个互不相同的元素。 所有不同计数的平方和为 12 + 12 + 12 = 3 。
提示:
1 <= nums.length <= 1001 <= nums[i] <= 100
解法
方法一:枚举
我们可以枚举子数组的左端点下标 \(i\),对于每个 \(i\),我们在 \([i, n)\) 的范围内枚举子数组的右端点下标 \(j\),并统计 \(nums[j]\) 的值,将其加入到集合 \(s\) 中,记 \(s\) 的大小为 \(cnt\),那么 \(nums[i..j]\) 的不同计数为 \(cnt\),将其平方后加入到答案中。
枚举结束后,返回答案即可。
时间复杂度 \(O(n^2)\),空间复杂度 \(O(n)\)。其中 \(n\) 是数组 \(nums\) 的长度。
1 2 3 4 5 6 7 8 9  |  | 
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17  |  | 
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18  |  | 
1 2 3 4 5 6 7 8 9 10 11 12 13 14  |  | 
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15  |  |