1498.Number of Subsequences That Satisfy the Given Sum Condition
===
###### tags: `Medium`,`Array`,`Two Pointers`,`Binary Search`,`Sorting`
[1498. Number of Subsequences That Satisfy the Given Sum Condition](https://leetcode.com/problems/number-of-subsequences-that-satisfy-the-given-sum-condition/)
### 題目描述
You are given an array of integers `nums` and an integer `target`.
Return *the number of **non-empty** subsequences of* `nums` *such that the sum of the minimum and maximum element on it is less or equal to* `target`. Since the answer may be too large, return it **modulo** 10^9^ + 7.
### 範例
**Example 1:**
```
Input: nums = [3,5,6,7], target = 9
Output: 4
Explanation: There are 4 subsequences that satisfy the condition.
[3] -> Min value + max value <= target (3 + 3 <= 9)
[3,5] -> (3 + 5 <= 9)
[3,5,6] -> (3 + 6 <= 9)
[3,6] -> (3 + 6 <= 9)
```
**Example 2:**
```
Input: nums = [3,3,6,8], target = 10
Output: 6
Explanation: There are 6 subsequences that satisfy the condition. (nums can have repeated numbers).
[3] , [3] , [3,3], [3,6] , [3,6] , [3,3,6]
```
**Example 3:**
```
Input: nums = [2,3,3,4,6,7], target = 12
Output: 61
Explanation: There are 63 non-empty subsequences, two of them do not satisfy the condition ([6,7], [7]).
Number of valid subsequences (63 - 2 = 61).
```
**Constraints**:
* 1 <= `nums.length` <= 10^5^
* 1 <= `nums[i]` <= 10^6^
* 1 <= `target` <= 10^6^
### 解答
#### Python
```python=
class Solution:
def numSubseq(self, nums: List[int], target: int) -> int:
n = len(nums)
MOD = 10 ** 9 + 7
nums.sort()
ans = 0
l, r = 0, n - 1
while l <= r:
if nums[l] + nums[r] <= target:
ans = (ans + pow(2, r - l, MOD)) % MOD
l += 1
else:
r -= 1
return ans
```
> [name=Yen-Chi Chen][time=Sun, May 7, 2023]
```python=
class Solution:
def numSubseq(self, nums: List[int], target: int) -> int:
nums.sort()
ans = 0
l, r = 0, len(nums) - 1
while l <= r:
ans <<= 1
if nums[l] + nums[r] <= target:
ans += 1
l += 1
else:
r -= 1
return ans % (10 ** 9 + 7)
```
> [name=Yen-Chi Chen][time=Sun, May 7, 2023]
#### Javascript
```javascript=
function numSubseq(nums, target) {
nums.sort((a, b) => a - b);
let count = 0;
let left = 0;
let right = nums.length - 1;
const mod = 1e9 + 7;
const pow2 = new Array(nums.length).fill(0);
pow2[0] = 1;
for (let i = 1; i < nums.length; i++) {
pow2[i] = (pow2[i - 1] * 2) % mod;
}
while (left <= right) {
if (nums[left] + nums[right] > target) {
right--;
} else {
count = (count + pow2[right - left]) % mod;
left++;
}
}
return count;
}
```
> [name=Marsgoat][time=Sun, May 7, 2023]
### Reference
[回到題目列表](https://hackmd.io/@Marsgoat/leetcode_every_day)