comments | difficulty | edit_url | rating | source | tags | |||
---|---|---|---|---|---|---|---|---|
true |
中等 |
2081 |
第 113 场双周赛 Q3 |
|
给你一个 二维 整数数组 coordinates
和一个整数 k
,其中 coordinates[i] = [xi, yi]
是第 i
个点在二维平面里的坐标。
我们定义两个点 (x1, y1)
和 (x2, y2)
的 距离 为 (x1 XOR x2) + (y1 XOR y2)
,XOR
指的是按位异或运算。
请你返回满足 i < j
且点 i
和点 j
之间距离为 k
的点对数目。
示例 1:
输入:coordinates = [[1,2],[4,2],[1,3],[5,2]], k = 5 输出:2 解释:以下点对距离为 k : - (0, 1):(1 XOR 4) + (2 XOR 2) = 5 。 - (2, 3):(1 XOR 5) + (3 XOR 2) = 5 。
示例 2:
输入:coordinates = [[1,3],[1,3],[1,3],[1,3],[1,3]], k = 0 输出:10 解释:任何两个点之间的距离都为 0 ,所以总共有 10 组点对。
提示:
2 <= coordinates.length <= 50000
0 <= xi, yi <= 106
0 <= k <= 100
我们可以用一个哈希表
接下来,我们枚举数组
时间复杂度
class Solution:
def countPairs(self, coordinates: List[List[int]], k: int) -> int:
cnt = Counter()
ans = 0
for x2, y2 in coordinates:
for a in range(k + 1):
b = k - a
x1, y1 = a ^ x2, b ^ y2
ans += cnt[(x1, y1)]
cnt[(x2, y2)] += 1
return ans
class Solution {
public int countPairs(List<List<Integer>> coordinates, int k) {
Map<List<Integer>, Integer> cnt = new HashMap<>();
int ans = 0;
for (var c : coordinates) {
int x2 = c.get(0), y2 = c.get(1);
for (int a = 0; a <= k; ++a) {
int b = k - a;
int x1 = a ^ x2, y1 = b ^ y2;
ans += cnt.getOrDefault(List.of(x1, y1), 0);
}
cnt.merge(c, 1, Integer::sum);
}
return ans;
}
}
class Solution {
public:
int countPairs(vector<vector<int>>& coordinates, int k) {
map<pair<int, int>, int> cnt;
int ans = 0;
for (auto& c : coordinates) {
int x2 = c[0], y2 = c[1];
for (int a = 0; a <= k; ++a) {
int b = k - a;
int x1 = a ^ x2, y1 = b ^ y2;
ans += cnt[{x1, y1}];
}
++cnt[{x2, y2}];
}
return ans;
}
};
func countPairs(coordinates [][]int, k int) (ans int) {
cnt := map[[2]int]int{}
for _, c := range coordinates {
x2, y2 := c[0], c[1]
for a := 0; a <= k; a++ {
b := k - a
x1, y1 := a^x2, b^y2
ans += cnt[[2]int{x1, y1}]
}
cnt[[2]int{x2, y2}]++
}
return
}
function countPairs(coordinates: number[][], k: number): number {
const cnt: Map<number, number> = new Map();
const f = (x: number, y: number): number => x * 1000000 + y;
let ans = 0;
for (const [x2, y2] of coordinates) {
for (let a = 0; a <= k; ++a) {
const b = k - a;
const [x1, y1] = [a ^ x2, b ^ y2];
ans += cnt.get(f(x1, y1)) ?? 0;
}
cnt.set(f(x2, y2), (cnt.get(f(x2, y2)) ?? 0) + 1);
}
return ans;
}