这 题 说 的 是 给 了 一 个 K—NN    每次查询离loc 最近的k个数 然后将这k个数的权值加起来除以k 赋值给 loc 这个位置上的 权值

 我说说 我的做法 假如 查询的是loc 这个位置 k 个 ,然后 就让 L=1 R= loc 对于每个 二分 的 mid  假设mid 是这k个数最左的那个的下标 然后对于每个最左的下标 我们可以知道 这k 个数的最右点在哪里 然后就判断 这个区间是否要左移 或者右移 左移 R=mid 右移 L=mid+1 然后不断的去调整 找到最后的L和R后用树状数组去维护就好了
#include <iostream>
#include <cstdio>
#include <string.h>
#include <algorithm>
using namespace std;
typedef int ll;
const int max_n =;
const int INF =(1e9)*;
struct point{
ll loc,num;
double val;
bool operator <(const point A)const{
return loc<A.loc;
}
}P[max_n];
int n,m;
double C[max_n];
int lowbit(int x){
return x&(-x);
}
void add(int x, double v){
while(x<=n){
C[x]+=v;
x+=lowbit(x);
}
}
double sum(int x){
double ans=;
while(x>){
ans+=C[x];
x-=lowbit(x);
}
return ans;
}
int id[max_n];
ll dist[max_n];
void binser(int &L, int &R,int loc, int num){
L=max(,loc-num);
R= loc;
ll S1,nu,S2;
while(L<R){
int mid =(R+L)/;
S1=dist[loc]-dist[mid];
nu = num-(loc-mid)+loc;
if(nu<loc){
L=mid+; continue;
}
if(nu>n){
R=mid;continue;
}
S2=dist[nu]-dist[loc];
if(S1>S2){
L=mid+;
}else {
R=mid;
}
}
L = min(L,loc);
R = num - ( loc - L ) + loc ;
L = min( L + , loc );
R = max( loc , R - );
int ge = R-loc + loc - L;
while(ge!=num){
if(R>=n||(L>&&dist[loc]-dist[L-]<dist[R+]-dist[loc])
||(L>&&dist[loc]-dist[L-]==dist[R+]-dist[loc]&&P[L-].num<P[R+].num))
L--;
else R++;
ge++;
}
}
int main()
{
int cas;
scanf("%d",&cas);
while(cas--){
for(int i=; i<=n; i++)
C[i]=0.0;
scanf("%d%d",&n,&m);
for(int i =; i<=n; i++){
ll loc;
double val;
scanf("%d%lf",&loc,&val);
P[i].loc=loc;
P[i].num=i;
P[i].val=val;
}
sort( P + , P + n + );
for(int i=; i <= n ;++i){
id[ P[i].num ] = i;
dist[ i ] = P[ i ].loc;
add( i , P[i].val );
}
dist[n+]=INF;
double ans=;
double S;
while(m--){
int loc, k;
scanf("%d%d",&loc,&k);
if(loc<||k<||k>=n)while(true);
loc=id[loc];
int L,R;
binser(L,R,loc,k);
add(loc,-P[loc].val);
S =sum(R)-sum(L-);
S=S/k;
ans=ans+S;
add(loc,S);
P[loc].val=S;
}
printf("%.3f\n",ans);
}
return ;
}

hdu5021 树状数组+二分的更多相关文章

  1. POJ 2828 Buy Tickets (线段树 or 树状数组+二分)

    题目链接:http://poj.org/problem?id=2828 题意就是给你n个人,然后每个人按顺序插队,问你最终的顺序是怎么样的. 反过来做就很容易了,从最后一个人开始推,最后一个人位置很容 ...

  2. TZOJ 4602 高桥和低桥(二分或树状数组+二分)

    描述 有个脑筋急转弯是这样的:有距离很近的一高一低两座桥,两次洪水之后高桥被淹了两次,低桥却只被淹了一次,为什么?答案是:因为低桥太低了,第一次洪水退去之后水位依然在低桥之上,所以不算“淹了两次”.举 ...

  3. POJ 2182 Lost Cows 【树状数组+二分】

    题目链接:http://poj.org/problem?id=2182 Lost Cows Time Limit: 1000MS   Memory Limit: 65536K Total Submis ...

  4. 树状数组+二分||线段树 HDOJ 5493 Queue

    题目传送门 题意:已知每个人的独一无二的身高以及排在他前面或者后面比他高的人数,问身高字典序最小的排法 分析:首先对身高从矮到高排序,那么可以知道每个人有多少人的身高比他高,那么取较小值(k[i], ...

  5. P2161 [SHOI2009]会场预约[线段树/树状数组+二分/STL]

    题目描述 PP大厦有一间空的礼堂,可以为企业或者单位提供会议场地.这些会议中的大多数都需要连续几天的时间(个别的可能只需要一天),不过场地只有一个,所以不同的会议的时间申请不能够冲突.也就是说,前一个 ...

  6. The Stream of Corning 2( 权值线段树/(树状数组+二分) )

    题意: 有两种操作:1.在[l,r]上插入一条值为val的线段 2.问p位置上值第k小的线段的值(是否存在) 特别的,询问的时候l和p合起来是一个递增序列 1<=l,r<=1e9:1< ...

  7. 牛客多校第3场 J 思维+树状数组+二分

    牛客多校第3场 J 思维+树状数组+二分 传送门:https://ac.nowcoder.com/acm/contest/883/J 题意: 给你q个询问,和一个队列容量f 询问有两种操作: 0.访问 ...

  8. UVA 11610 Reverse Prime (数论+树状数组+二分,难题)

    参考链接http://blog.csdn.net/acm_cxlove/article/details/8264290http://blog.csdn.net/w00w12l/article/deta ...

  9. HDU 2852 KiKi's K-Number 树状数组 + 二分

    一共最多才100000个数,并且数值范围0~100000. 树状数组 C[i] 记录数值为 i 的数有多少个. 删除时如果Query( a ) - Query( a - 1 ) == 0 则该数不存在 ...

随机推荐

  1. Apache Prefork、Worker和Event三種MPM分析

    三種MPM介紹 Apache 2.X  支持插入式並行處理模塊,稱爲多路處理模塊(MPM).在編譯apache時必須選擇也只能選擇一個MPM,對類UNIX系統,有幾個不同的MPM可供選擇,它們會影響到 ...

  2. 在map中一个key中存多个值

    一说到map都想到key-value键值队存在.key可以为最多一个null的key. 今天开发中一个业务需求,在map中一个key中存多个对象. 我首先想到Map<String,List> ...

  3. bootstrap里面的popover组件如何使鼠标移入可以对弹出框进行一系列的操作

    在bootstrap里面,有一个组件很可爱,它就是popover,它是对标签title属性的优化,奉上连接一枚:http://docs.demo.mschool.cn/components/popov ...

  4. img标签-srcset属性

    今天看前辈的代码时,发现img标签有个陌生的srcset属性,如下: 1 <img class="Avatar" src="https://pic3.zhimg.c ...

  5. 谷歌Volley网络框架讲解——第一篇

    自从公司新招了几个android工程师后,我清闲了些许.于是就可以有时间写写博客,研究一些没来的研究的东西. 今年的谷歌IO大会上,谷歌推出了自己的网络框架——Volley.不久前就听说了但是没有cl ...

  6. Windows域的相关操作

    一.windows域账户组操作: net group /domain #查看所有组 net group GROUP-NAME /domain #查看某一个组 net group GROUP-NAME ...

  7. 基于TINY4412的Andorid开发-------简单的LED灯控制

    参考资料: <Andriod系统源代码情景分析> <嵌入式Linux系统开发完全手册_基于4412_上册> 作者:彭东林 邮箱:pengdonglin137@163.com 平 ...

  8. 【BZOJ4424】Cf19E Fairy DFS树

    [BZOJ4424]Cf19E Fairy Description 给定 n 个点,m 条边的无向图,可以从图中删除一条边,问删除哪些边可以使图变成一个二分图. Input 第 1 行包含两个整数 n ...

  9. c# Sockect 通信

    1.Server using System; using System.Collections.Generic; using System.Text; //添加Socket类 using System ...

  10. JFinal的启动源码解读

    本文对Jfinal的启动源码做解释说明. PS:Jfinal启动容器可基于Tomcat/Jetty等web容器启动,本文基于Jetty的启动方式做启动源码的解读和分析,tomcat类似. 入口  JF ...