2903.找出满足差值条件的下标 I

【LetMeFly】2903.找出满足差值条件的下标 I:暴力模拟

力扣题目链接:https://leetcode.cn/problems/find-indices-with-index-and-value-difference-i/

给你一个下标从 0 开始、长度为 n 的整数数组 nums ,以及整数 indexDifference 和整数 valueDifference

你的任务是从范围 [0, n - 1] 内找出  2 个满足下述所有条件的下标 ij

  • abs(i - j) >= indexDifference
  • abs(nums[i] - nums[j]) >= valueDifference

返回整数数组 answer。如果存在满足题目要求的两个下标,则 answer = [i, j] ;否则,answer = [-1, -1] 。如果存在多组可供选择的下标对,只需要返回其中任意一组即可。

注意:ij 可能 相等

 

示例 1:

输入:nums = [5,1,4,1], indexDifference = 2, valueDifference = 4
输出:[0,3]
解释:在示例中,可以选择 i = 0 和 j = 3 。
abs(0 - 3) >= 2 且 abs(nums[0] - nums[3]) >= 4 。
因此,[0,3] 是一个符合题目要求的答案。
[3,0] 也是符合题目要求的答案。

示例 2:

输入:nums = [2,1], indexDifference = 0, valueDifference = 0
输出:[0,0]
解释:
在示例中,可以选择 i = 0 和 j = 0 。 
abs(0 - 0) >= 0 且 abs(nums[0] - nums[0]) >= 0 。 
因此,[0,0] 是一个符合题目要求的答案。 
[0,1]、[1,0] 和 [1,1] 也是符合题目要求的答案。 

示例 3:

输入:nums = [1,2,3], indexDifference = 2, valueDifference = 4
输出:[-1,-1]
解释:在示例中,可以证明无法找出 2 个满足所有条件的下标。
因此,返回 [-1,-1] 。

 

提示:

  • 1 <= n == nums.length <= 100
  • 0 <= nums[i] <= 50
  • 0 <= indexDifference <= 100
  • 0 <= valueDifference <= 50

解题方法:两层循环

第一层循环从$0$到$n - 1$枚举$i$,第二层循环从$i$到$n - 1$枚举$j$。

枚举过程中如果满足了$j-i\geq indexDifference$和$abs(nums[i]-nums[j])\geq valueDifference$,则立刻返回[i, j]

否则(循环结束)返回[-1, -1]

  • 时间复杂度$O(n^2)$
  • 空间复杂度$O(1)$

AC代码

C++

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
#ifdef _WIN32
#include "_[1,2]toVector.h"
#endif

class Solution {
public:
vector<int> findIndices(vector<int>& nums, int indexDifference, int valueDifference) {
for (int i = 0; i < nums.size(); i++) {
for (int j = i; j < nums.size(); j++) {
if (j - i >= indexDifference && abs(nums[i] - nums[j]) >= valueDifference) {
return {i, j};
}
}
}
return {-1, -1};
}
};

Go

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
package main

func abs(x int) int {
if x >= 0 {
return x;
}
return -x;
}

func findIndices(nums []int, indexDifference int, valueDifference int) []int {
for i := 0; i < len(nums); i++ {
for j := i; j < len(nums); j++ {
if j - i >= indexDifference && abs(nums[i] - nums[j]) >= valueDifference {
return []int {i, j};
}
}
}
return []int {-1, -1};
}

Java

1
2
3
4
5
6
7
8
9
10
11
12
class Solution {
public int[] findIndices(int[] nums, int indexDifference, int valueDifference) {
for (int i = 0; i < nums.length; i++) {
for (int j = i; j < nums.length; j++) {
if (j - i >= indexDifference && Math.abs(nums[i] - nums[j]) >= valueDifference) {
return new int[]{i, j};
}
}
}
return new int[]{-1, -1};
}
}

Python

1
2
3
4
5
6
7
8
9
# from typing import List

class Solution:
def findIndices(self, nums: List[int], indexDifference: int, valueDifference: int) -> List[int]:
for i in range(len(nums)):
for j in range(i, len(nums)):
if j - i >= indexDifference and abs(nums[i] - nums[j]) >= valueDifference:
return [i, j]
return [-1, -1]

同步发文于CSDN和我的个人博客,原创不易,转载经作者同意后请附上原文链接哦~

Tisfy:https://letmefly.blog.csdn.net/article/details/139195914


2903.找出满足差值条件的下标 I
https://blog.letmefly.xyz/2024/05/25/LeetCode 2903.找出满足差值条件的下标I/
作者
Tisfy
发布于
2024年5月25日
许可协议