扫二维码与项目经理沟通
我们在微信上24小时期待你的声音
解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流
有 N 家旅馆,每家旅馆都有位置和价格,有 M 个客人希望找到一家价格可接受的最近旅馆。
10年积累的成都做网站、网站制作经验,可以快速应对客户对网站的新想法和需求。提供各种问题对应的解决方案。让选择我们的客户得到更好、更有力的网络服务。我虽然不认识你,你也不认识我。但先网站设计后付款的网站建设流程,更有广东免费网站建设让你可以放心的选择与我们合作。二 输入和输出 1 输入每个测试用例的第 1 行都包含两个整数 N(N ≤200000)和 M(M ≤20000),分别表示旅馆数量和客人数量。接下来的 N 行,每行都包含3个整数 x、y 和 c(1≤x , y,c ≤N),其中 x、y 是旅馆的坐标,c 是其价格,保证 N 个旅馆都有不同的 x、y 和 c 。接下来的 M 行,每行都描述一个客人的查询,其中 x 、y 是客人的坐标,c 是客人可接受的最高价格。
2 输出对每个客人的查询,都单行输出价格可接受的最近旅馆。若有多个旅馆的价格可以接受且距离最小,则输出第 1 个。
三 输入和输出样例 1 输入样例2 输出样例2
3 3
1 1 1
3 2 3
2 3 2
2 2 1
2 2 2
2 2 3
5 5
1 4 4
2 1 2
4 5 3
5 2 1
3 3 5
3 3 1
3 3 2
3 3 3
3 3 4
3 3 5
四 分析和设计 1 分析1 1 1
2 3 2
3 2 3
5 2 1
2 1 2
2 1 2
1 4 4
3 3 5
本问题为三维数据,包括二维坐标和价格,可采用 KD 树解决。
2 算法设计(1)根据输入数据的二维坐标创建 KD 树。
(2)在 KD 树中查询距离 p 最近且价格不超过 c 的旅馆。
3 算法实现查询距离给定点 p 最近且价格不超过c 的点,算法步骤如下。
(1)创建一个序对,第 1 个元素记录当前节点到 p 的距离,第 2 个元素记录当前节点;然后定义一个变量 res,存储离 p 最近且价格不超过 c 的序对。
(2)查询时从树根开始,首先计算树根与 p 的距离,用 cur 记录距离、节点序对。
(3)若 p.x [dim] (4)若 lc 不空,则在 lc 中递归查询 query(lc, m , dep+1, p)。 (5)若还没有答案,且当前节点的价格小于 p 的价格,则更新答案为当前节点 res=cur,flag=1,还需要在右子树中查询;若当前节点的价格小于 p 的价格且当前节点到 p 的距离小于 res 到 p 的距离,或者 两者相等但 cur 的序号在前,则更新 res=cur;若以 p 为球心且以 p 到 res 的距离为半径的圆与树根的另一区域相交,则 flag=1,还需要在右子树中查询。 (6)若 rc 不空且 flag=1,则在 rc 中递归查询 query(rc,m,dep+1, p)。 你是否还在寻找稳定的海外服务器提供商?创新互联www.cdcxhl.cn海外机房具备T级流量清洗系统配攻击溯源,准确流量调度确保服务器高可用性,企业级服务器适合批量采购,新人活动首月15元起,快前往官网查看详情吧
六 测试 package com.platform.modules.alg.alglib.hdu5992;
import javafx.util.Pair;
import java.util.Arrays;
public class Hdu5992 {
private int inf = 0x3f3f3f3f;
private int maxn = 200000 + 10;
int idx;
public String output = "";
int sz[] = new int[maxn<< 2];
Node a[] = new Node[maxn];
Node kd[] = new Node[maxn<< 2];
Pair
文章题目:找旅馆问题-创新互联
新闻来源:http://kswjz.com/article/espos.html
我们在微信上24小时期待你的声音
解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流