HDU - 4995 - Revenge of kNN
题目链接 : https://vjudge.net/problem/HDU-4995
题目大意 : 读入n个点的坐标与该点所拥有的值val,进行m次查询,对于每一次查询,读入该点的坐标,计算离该点最近的k个点的值(距离相同的索引小的优先),进行求和求平均,
然后更新改点的值,最后输出更新的值的和。
题目分析 : 一个比较不错的模拟的题目,可以对坐标值和 索引进行hash来优化计算时间。
其他进行模拟即可,注意读入的值并不是有序的,需要先进行排序。
代码实现 :
#include <iostream>
#include <cstring>
#include <queue>
#include <algorithm>
#include <cstdio>
using namespace std;
int m,n,k;
struct node
{
double point;
double val;
int id;
};
bool comp(const node &a,const node& b)
{
return a.point<b.point;
}
+];
node nodes[+];
void init()
{
cin>>n>>m>>k;
;i<n;i++)
{
double a;
double b;
scanf("%lf%lf",&a,&b);
nodes[i].point=a;
nodes[i].val=b;
nodes[i].id = i;
}
sort(nodes,nodes+n,comp);
;i<n;i++)
{
hashs[nodes[i].id+]=i;
}
}
double solve()
{
;
;i<m;i++)
{
int t;
scanf("%d",&t);
// cout<<t<<endl;
int mid=hashs[t];
,r=mid+;
int K=k;
;
while(K--)
{
&&r<n)
{
double d1=nodes[l].point;
double d2=nodes[r].point;
double t1=nodes[mid].point-d1;
double t2=d2-nodes[mid].point;
// cout<<t1<<" "<<t2<<" "<<"*"<<endl;
if(t1<t2)
{
sum+=nodes[l].val;
// cout<<nodes[l].val<<" "<<l<<endl;
l--;
}
else if(t1>t2)
{
sum+=nodes[r].val;
// cout<<nodes[r].val<<" "<<r<<endl;
r++;
}else if(t1==t2)
{
if(nodes[l].id<nodes[r].id)
{
sum+=nodes[l].val;
l--;
}
else
{
sum+=nodes[r].val;
r++;
}
}
}
)
{
sum+=nodes[l].val;
// cout<<nodes[l].val<<" "<<l<<endl;
l--;
}else if(r<n)
{
sum+=nodes[r].val;
// cout<<nodes[r].val<<" "<<r<<endl;
r++;
}
}
// cout<<sum<<" *"<<endl;
sum=sum/k;
//cout<<sum<<endl;
SUM+=sum;
nodes[mid].val=sum;
}
return SUM;
}
int main()
{
int T;
cin>>T;
while(T--)
{
init();
double sum=solve();
printf("%.6lf\n",sum);
}
;
}
HDU - 4995 - Revenge of kNN的更多相关文章
- hdu 4995(离散化下标+模拟)
Revenge of kNN Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)To ...
- BestCoder9 1003 Revenge of kNN(hdu 4995) 解题报告
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4995 题目意思:在一个一维坐标轴上,给出位置 xi 和值 vi,对于 M 次询问,每次询问给出inde ...
- HDU 5019 Revenge of GCD(数学)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5019 Problem Description In mathematics, the greatest ...
- HDU - 4994 Revenge of Nim (取石子游戏)
Problem Description Nim is a mathematical game of strategy in which two players take turns removing ...
- hdu 4995 离线处理+模拟
http://acm.hdu.edu.cn/showproblem.php?pid=4995 给定一维坐标下的n个点,以及每个点的权值,有m次查询,每次将查询的x点上的权值修改为离x最近的k个点权值的 ...
- HDU 4996 Revenge of LIS(DP)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4996 题意:求1到n的全排列中,有多少个排列的最长上升子列长度为K? 思路:对于当前的最长上升子列,我 ...
- hdu 4099 Revenge of Fibonacci 大数+压位+trie
最近手感有点差,所以做点水题来锻炼一下信心. 下周的南京区域赛估计就是我的退役赛了,bless all. Revenge of Fibonacci Time Limit: 10000/5000 MS ...
- hdu 4099 Revenge of Fibonacci 字典树+大数
将斐波那契的前100000个,每个的前40位都插入到字典树里(其他位数删掉),然后直接查询字典树就行. 此题坑点在于 1.字典树的深度不能太大,事实上,超过40在hdu就会MLE…… 2.若大数加法时 ...
- hdu 4099 Revenge of Fibonacci Trie树与模拟数位加法
Revenge of Fibonacci 题意:给定fibonacci数列的前100000项的前n位(n<=40);问你这是fibonacci数列第几项的前缀?如若不在前100000项范围内,输 ...
随机推荐
- Thinkphp 3.0-3.1版代码执行漏洞
近日360库带计划中播报的ThinkPHP扩展类库的漏洞已经查明原因:系官方扩展模式中的Lite精简模式中存在可能的漏洞(原先核心更新安全的时候 并没有更新模式扩展部分,现已更新).对于使用标准模式或 ...
- 快速上手 Kotlin 的 11 招
本文转载自 Kotlin 公众号(KotlinX) 作者:bennyhuo 最近经常会收到一些 "用 Kotlin 怎么写" 的问题,作为有经验的程序员,我们已经掌握了一门或者多门 ...
- 利用angular给节点添加样式
<!DOCTYPE html> <html lang="en" ng-app="myapp"> <head> <met ...
- Nginx学习笔记1-Nginx功能模块以及进程管理
1. 功能 1.1. 功能描述 使用缓存加速反向代理,简单负载均衡和容错: 使用缓存机制加速远程FastCGI服务器的访问: 模块化结构: 基本的HTTP功能: 邮 ...
- 初步探究java中程序退出、GC垃圾回收时,socket tcp连接的行为
初步探究java中程序退出.GC垃圾回收时,socket tcp连接的行为 今天在项目开发中需要用到socket tcp连接相关(作为tcp客户端),在思考中发觉需要理清socket主动.被动关闭时发 ...
- AVAudioSession(2):定义一个 Audio Session
本文转自:AVAudioSession(2):定义一个 Audio Session | www.samirchen.com 本文内容主要来源于 Defining an Audio Session. A ...
- WCF学习——构建第二个WCF应用程序(四)
一.WCF服务端应用程序 1.创建WCF服务端应用程序项目 打开Visual Studio 2013,在菜单上点击文件->新建->项目->WCF服务应用程序.在弹出界面的" ...
- 在Cenos系统安装Python3.5版本,使P2和P3共存
首先Cenos安装好后,系统自带python2.6版本 输入>>>exit() 退出 使用迅雷下载python3.5 链接:https://www.python.org/ft ...
- Spring Web 配置文件加载路径问题
Spring: 定位 载入 注册 我们常用的加载context文件的方法有如下三个: 1.FileSystemXmlApplicationContext 这个方法是从文件绝对路径加载配置文 ...
- 禁用自动映射的 Exchange 邮箱
客户最近询问他们无法从用户的Outlook配置文件中删除邮箱.在这种情况下,它们是共享邮箱,并出现在Outlook的左窗格中.但原因和解决方法同样适用于用户邮箱.并且 无论用户邮箱在本地 Exchan ...