1656 Count Good Triplets
1656 Count Good Triplets
Count Good Triplets 
Given an array of integers arr, and three integers a, b and c. You need to find the number of good triplets.
A triplet (arr[i], arr[j], arr[k]) is good if the following conditions are true:
1
2
3
4
0 <= i < j < k < arr.length
|arr[i] - arr[j]| <= a
|arr[j] - arr[k]| <= b
|arr[i] - arr[k]| <= c
| Where | x | denotes the absolute value of x. |
Return* the number of good triplets*.
Example 1:
1
2
3
4
5
**Input:** arr = [3,0,1,1,9,7], a = 7, b = 2, c = 3
**Output:** 4
**Explanation:** There are 4 good triplets: [(3,0,1), (3,0,1), (3,1,1), (0,1,1)].
Example 2:
1
2
3
4
5
**Input:** arr = [1,1,2,2,3], a = 0, b = 0, c = 1
**Output:** 0
**Explanation: **No triplet satisfies all conditions.
Constraints:
1
2
3
3 <= arr.length <= 100
0 <= arr[i] <= 1000
0 <= a, b, c <= 1000
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
class Solution:
def countGoodTriplets(self, arr: List[int], a: int, b: int, c: int) -> int:
res = []
for i, k in enumerate(arr):
for j,l in enumerate(arr[i+1:]):
diff = abs(k - l)
if diff <= a:
res.append((i,i+1+j))
ans = 0
#print(res)
for p in res:
for k,m in enumerate(arr[p[1]+1:]):
if abs(arr[p[1]] - m) <= b and abs(arr[p[0]]-m) <= c:
ans += 1
return ans
print(res)
This post is licensed under CC BY 4.0 by the author.