http://acm.hdu.edu.cn/showproblem.php?pid=4995

给定一维坐标下的n个点,以及每个点的权值,有m次查询,每次将查询的x点上的权值修改为离x最近的k个点权值的平均和,有相同取序号小的。最后输出修改值的总和。

先离线处理出每个x点对应的所有最近的k个点,然后模拟即可

#include <cstdio>
#include <cstdlib>
#include <cmath>
#include <cstring>
#include <string>
#include <queue>
#include <map>
#include <iostream>
#include <algorithm>
using namespace std;
#define RD(x) scanf("%d",&x)
#define RD2(x,y) scanf("%d%d",&x,&y)
#define RD3(x,y,z) scanf("%d%d%d",&x,&y,&z)
#define clr0(x) memset(x,0,sizeof(x))
typedef long long LL;
const int maxn = 100005;
int n,m,k;
int g[maxn][11];
double v[maxn];
struct node{
int x,i;
}p[maxn];
bool cmp(node a,node b)
{
return a.x < b.x;
}
bool lorr(int x,int l,int r)
{
if(r >= n)
return true;
if(l < 0)
return false;
if(p[x].x - p[l].x != p[r].x - p[x].x)
return p[x].x - p[l].x < p[r].x - p[x].x;
return p[l].i < p[r].i;
}
void getK(int x)
{
int l = x - 1,r = x + 1,id = p[x].i;
for(int i = 0;i < k;++i)
if(lorr(x,l,r))
g[id][i] = p[l--].i;
else
g[id][i] = p[r++].i;
}
void init () {
scanf("%d%d%d", &n, &m, &k); for (int i = 0; i < n; i++) {
scanf("%d%lf", &p[i].x, &v[i]);
p[i].i = i;
} sort(p , p + n, cmp); for (int i = 0; i < n; i++)
getK(i);
}
int main() {
int _,x;RD(_);while(_--){
init();
double ans = 0;
while(m--){
RD(x);
x--;
double sum = 0;
for(int i = 0;i < k;++i)
sum += v[g[x][i]];
v[x] = sum/k;
ans += v[x];
}
printf("%.6lf\n",ans);
}
return 0;
}

最新文章

  1. 深入理解javascript原型和闭包(1)---一切都是对象
  2. EF CodeFirst 创建数据库
  3. Microsoft Visual Studio 2010 VSTS单元测试指南
  4. .Net身份验证概述
  5. ASP.NET MVC5 入门
  6. Linux下安装Scim-googlepinyin输入法和设置Sublime Text中文输入
  7. java8 新特性
  8. deflate——过时的网页压缩格式,最好禁用[转]
  9. React 页面间传值的个人总结
  10. ABP 找不到版本为 (&gt;= 1.0.0-preview1-27891) 的包 Microsoft.AspNetCore.SignalR 错误
  11. JavaScript -- 原型:prototype的使用
  12. [转载]EXCEL绝对引用中$A$1、A$1、$A1三个的区别?
  13. java 日志脱敏框架 sensitive-新版本0.0.2-深度拷贝,属性为对象和集合的支持
  14. Key-Value 数据库简介
  15. hdu 2097 sky数(进制转换)
  16. CSS: pseudo-classes and pseudo-elements
  17. 用Quartz 2D画小黄人
  18. 【PyQt5-Qt Designer】pyqtSignal()-高级自定义信号与槽
  19. IE无法安装Activex控件
  20. innerHTML和 innerText的区别

热门文章

  1. k-means处理图片
  2. springmvc处理url请求步骤
  3. Django入门-框架目录介绍
  4. Baidu URL的部分参数
  5. javaWeb后端学习记录
  6. 84直方图最大矩形覆盖 &#183; Largest Rectangle in Histogram
  7. [leetcode]277. Find the Celebrity谁是名人
  8. adf 笔记
  9. js 递归调用
  10. Golang之时间格式化,计时器