【题目】
给你两个整数数组 arr1 , arr2 和一个整数 d ,请你返回两个数组之间的 距离值
「距离值」 定义为符合此描述的元素数目:对于元素 arr1[i] ,不存在任何元素 arr2[j] 满足 |arr1[i]-arr2[j]| <= d
来源:leetcode
链接:https://leetcode-cn.com/problems/find-the-distance-value-between-two-arrays/
【示例】
输入:arr1 = [4,5,8], arr2 = [10,9,1,8], d = 2
输出:2
解释:
对于 arr1[0]=4 我们有:
|4-10|=6 > d=2
|4-9|=5 > d=2
|4-1|=3 > d=2
|4-8|=4 > d=2
对于 arr1[1]=5 我们有:
|5-10|=5 > d=2
|5-9|=4 > d=2
|5-1|=4 > d=2
|5-8|=3 > d=2
对于 arr1[2]=8 我们有:
|8-10|=2 <= d=2
|8-9|=1 <= d=2
|8-1|=7 > d=2
|8-8|=0 <= d=2
【代码】
class Solution {
public:
int findTheDistanceValue(vector<int>& arr1, vector<int>& arr2, int d) {
int cnt=0;
for(auto x:arr1){
int flag=0;
for(auto y:arr2)
if(abs(x-y)<=d){
flag=1;
break;
}
if(!flag)
cnt++;
}
return cnt;
}
};
【方法二】
class Solution {
public:
int findTheDistanceValue(vector<int>& arr1, vector<int>& arr2, int d) {
int cnt=0;
bool flag;
for(auto x:arr1){
flag=true;
for(auto y:arr2)
flag&=abs(x-y)>d;
cnt+=flag;
}
return cnt;
}
};