QOJ.ac

QOJ

IDProblemSubmitterResultTimeMemoryLanguageFile sizeSubmit timeJudge time
#601490#142. 平面最近点对learn_bw0 0ms0kbPython32.5kb2024-09-30 01:43:142024-09-30 01:43:14

Judging History

你现在查看的是最新测评结果

  • [2024-09-30 01:43:14]
  • 评测
  • 测评结果:0
  • 用时:0ms
  • 内存:0kb
  • [2024-09-30 01:43:14]
  • 提交

answer

def closest_pair(points):
    # 按照横坐标排序
    points.sort(key=lambda point:point[0]) 
    def _closest_pair(px, py):
        # 小于等于3个点,不需要分治,直接计算
        if len(px) <= 3:
            min_dist = float('inf')
            for i in range(len(px)):
                for j in range(i+1,len(px)):
                    dist = distance(px[i], px[j])
                    if dist < min_dist:
                        min_dist = dist
            return min_dist
        # 找到横坐标中间点
        mid = len(px)//2 
        Qx = px[:mid]
        Rx = px[mid:]
        midpoint = px[mid][0]
        # 找到按纵坐标排序的列表里面横坐标小于等于midpoint的点
        Qy = [p for p in py if p[0] <= midpoint]
        Ry = [p for p in py if p[0] > midpoint]
        dl = _closest_pair(Qx, Qy)
        dr = _closest_pair(Rx, Ry)
        # 比较横坐标中间点左右两边点集内的最小距离
        d = min(dl, dr)
        #找到横坐标中间点左右d的条带,且是已经按照纵坐标排好序的,可以节省时间复杂度不需要在递归函数里排序
        strip = [p for p in py if abs(p[0] - midpoint) < d]
        strip_l = [p for p in strip if p[0] - midpoint < 0]
        strip_r = [p for p in strip if p[0] - midpoint > 0]
        for p in strip_l:
            p_index = strip.index(p)
        #根据鸽笼原理,纵向为2d,横向为d的区域内最多有6个点到p的距离<d
            count = 0
            r_index = p_index - 1
            while r_index >= 0 and count < 4:
                if strip[r_index] in strip_r:
                    count += 1
                    dist = distance(p, strip[r_index])
                    if dist < d:
                        d = dist
                r_index -= 1
            count = 0
            r_index = p_index + 1
            while r_index < len(strip) and count < 4:
                if strip[r_index] in strip_r:
                    count += 1
                    dist = distance(p, strip[r_index])
                    if dist < d:
                        d = dist
                r_index += 1
        return d
    # 按照纵坐标排序
    py = sorted(points, key=lambda point:point[1])
    return _closest_pair(points, py)
import sys
n = int(sys.stdin.readline().strip())
points = []
for _ in range(n):
    points.append(tuple(map(int, sys.stdin.readline().strip().split())))
#points = [(2, 3), (12, 30), (40, 50), (5, 1), (12, 10), (3, 4)]
print(closest_pair(points))

Details

Tip: Click on the bar to expand more detailed information

Subtask #1:

score: 0
Dangerous Syscalls

Test #1:

score: 0
Dangerous Syscalls

input:

2933
19320 28055
2053 27470
14635 1378
27582 9822
28729 107
22351 3093
17670 379
23901 4686
27182 12261
19443 8467
24208 20283
10763 10584
25953 28380
28290 27394
19572 14769
4024 12401
23295 3267
26949 176
13416 4517
23856 15413
26260 18957
18275 24409
999 3873
28202 14686
25446 2822
24009 8949
114...

output:


result:


Subtask #2:

score: 0
Skipped

Dependency #1:

0%

Subtask #3:

score: 0
Skipped

Dependency #1:

0%

Subtask #4:

score: 0
Skipped

Dependency #1:

0%

Subtask #5:

score: 0
Skipped

Dependency #1:

0%