[Codeforces 1053C] Putting Boxes Together
Link:
Solution:
先推出一个结论:
最后必有一个点不动且其为权值上最中间的一个点
证明用反证证出如果不在中间的点必有一段能用代价少的替代多的
这样问题转换为求出区间第一个大于权值和一半的点,并求结果
如果只考虑半边的结果为$\sum_{i=1}^{mid} (pos[mid]-pos[i]-(mid-i))*w[i]$
将$pos[i]$修改为$pos[i]-i$之后维护$\sum pos[i]*w[i]$的和即可
以上操作可以用两颗线段树来维护
注意:
1、维护$w[i]$时不能取模!
2、对于求权值中间点可以二分+树状数组也可以直接在线段树上二分
线段树上二分时注意如果已经在区间内查询值要不断更新
Code:
#include <bits/stdc++.h> using namespace std;
#define X first
#define Y second
#define pb push_back
#define mid ((l+r)>>1)
#define lc k<<1,l,mid
#define rc k<<1|1,mid+1,r
typedef double db;
typedef long long ll;
typedef pair<int,int> P;
const int MAXN=5e5+,INF=<<,MOD=1e9+; struct SGT
{
ll seg[MAXN<<];
//分清何时要取模
void Update(int a,ll x,int f,int k,int l,int r)
{
if(l==r)
{seg[k]+=x;if(f) seg[k]%=MOD;return;}
if(a<=mid) Update(a,x,f,lc);
else Update(a,x,f,rc);
seg[k]=seg[k<<]+seg[k<<|];
if(f) seg[k]%=MOD;
}
ll Query(int a,int b,int f,int k,int l,int r)
{
if(a<=l&&r<=b) return seg[k];
ll ret=;
if(a<=mid) ret+=Query(a,b,f,lc);
if(b>mid) ret+=Query(a,b,f,rc);
return f?ret%MOD:ret;
}
//注意线段树二分的处理及此处的引用
int Find(int a,int b,ll &x,int k,int l,int r)
{
if(a<=l&&r<=b)
{
if(seg[k]<x){x-=seg[k];return INF;}
if(l==r) return l;
if(x<=seg[k<<]) return Find(a,b,x,lc);
else{x-=seg[k<<];return Find(a,b,x,rc);}
}
int ret=INF;
if(a<=mid)
ret=min(ret,Find(a,b,x,lc));
if(b>mid&&ret==INF)
ret=min(ret,Find(a,b,x,rc));
return ret;
}
}sw,sm;
int n,q,x,y,pos[MAXN],w[MAXN]; int main()
{
scanf("%d%d",&n,&q);
for(int i=;i<=n;i++)
scanf("%d",&pos[i]),pos[i]-=i;
for(int i=;i<=n;i++)
{
scanf("%d",&w[i]);
sw.Update(i,w[i],,,,n);
sm.Update(i,1ll*w[i]*pos[i],,,,n);
} while(q--)
{
scanf("%d%d",&x,&y);
if(x<)
{
x=-x;
sw.Update(x,-w[x],,,,n);
sm.Update(x,-1ll*w[x]*pos[x],,,,n);
w[x]=y;
sw.Update(x,w[x],,,,n);
sm.Update(x,1ll*w[x]*pos[x],,,,n);
}
else
{
//此时不能取模
ll sum=(sw.Query(x,y,,,,n)+)/;
int p=sw.Find(x,y,sum,,,n);
ll t1=(sw.Query(x,p,,,,n)*pos[p]%MOD-sm.Query(x,p,,,,n)+MOD)%MOD;
ll t2=(-sw.Query(p+,y,,,,n)*pos[p]%MOD+sm.Query(p+,y,,,,n)+MOD)%MOD;
printf("%lld\n",(t1+t2)%MOD);
}
}
return ;
}
[Codeforces 1053C] Putting Boxes Together的更多相关文章
- Codeforces 1053C Putting Boxes Together 树状数组
原文链接https://www.cnblogs.com/zhouzhendong/p/CF1053C.html 题目传送门 - CF1053C 题意 有 $n$ 个物品,第 $i$ 个物品在位置 $a ...
- 2018.09.24 codeforces 1053C. Putting Boxes Together(线段树)
传送门 就是让你维护动态的区间带权中位数. 然而昨晚比赛时并没有调出来. 想找到带权中位数的中点可以二分(也可以直接在线段树上找). 也就是二分出第一个断点,使得断点左边的和恰好大于或等于断点右边的和 ...
- Codeforces 1053 C - Putting Boxes Together
C - Putting Boxes Together 思路: 求带权中位数 用树状数组维护修改 代码: #pragma GCC optimize(2) #pragma GCC optimize(3) ...
- CodeForces 1058 F Putting Boxes Together 树状数组,带权中位数
Putting Boxes Together 题意: 现在有n个物品,第i个物品他的位置在a[i],他的重量为w[i].每一个物品移动一步的代价为他的w[i].目前有2种操作: 1. x y 将第x的 ...
- Putting Boxes Together CodeForces - 1030F (带权中位数)
#include <iostream> #include <algorithm> #include <cstdio> #include <math.h> ...
- Codeforces 488B - Candy Boxes
B. Candy Boxes 题目链接:http://codeforces.com/problemset/problem/488/B time limit per test 1 second memo ...
- Educational Codeforces Round 31- D. Boxes And Balls
D. Boxes And Balls time limit per test2 seconds memory limit per test256 megabytes 题目链接:http://codef ...
- [CF1053C]Putting Boxes Together(线段树)
http://codeforces.com/blog/entry/62013 两个结论: 1.一定有一个箱子不用动. 2.不动的箱子一定是加权前缀和为S/2的那个. 1显然,2由1易得. 于是问题变为 ...
- CF1030F Putting Boxes Together
昨晚的比赛题.(像我这种蒟蒻只能打打div2) 题意 给你$n$个物品,每一个物品$i$,有一个权值$w_i$和一个位置$a_i$,定义移动一个物品$i$到位置$t$的代价为$w_i * \left ...
随机推荐
- WP8.1 Windows Phone 8.1开发:何如定义Pivot头部样式、定义Pivot头部颜色
Windows Phone 8.1 ,如何自定义Pivot头部样式?用Pivot控件完成这样的效果. 网上找了好久,只找到了windows phone 8的解决方案. 终于一个大神给支了招,我觉得我有 ...
- 使用JQGrid 问题汇总 不定时更新
jqgrid左下角的复杂搜索框显示为下拉框样式searchoptions: { value: ": 全部; 1: 在用; 2: 报废", sopt: ['eq'] } jqgrid ...
- 9.1docker容器 跨主机连接
open vswitch 实现跨主机容器连接 准备条件 将本地的网卡 与新建的网桥建立连接 配置 docker 启动项 weave实现跨主机容器连接 null
- 64_j2
jetty-websocket-server-9.4.3-3.v20170317.fc26.n..> 14-Apr-2017 12:03 62034 jetty-websocket-servle ...
- 64_f1
FUR-0.4.6-13.fc26.x86_64.rpm 13-Feb-2017 23:32 45882 Falcon-0.9.6.8-11.fc26.i686.rpm 13-Feb-2017 23: ...
- CSS原生布局方式
前言 网页原生布局的方法其实网上有很多,大概为Flow(流动布局模型).Float(浮动布局模型).Layer(层级布局模型).<!--more--> Flow布局 流动布局模型其实就是默 ...
- 重写Alert
var isIE = navigator.appName.indexOf("Internet Explorer") != -1;var oldAlert = window.aler ...
- network-scoket
server: using System; using System.Collections.Generic; using System.Linq; using System.Text; using ...
- python_day5学习笔记
一.正则表达式 字符: \d 匹配任何十进制数:相当于类[0-9] \D 匹配任何非数字字符:相当于类[^0-9] \s 匹配任何空白字符:相当于类[ \t\n\r\f\v] \S 匹配任何非空 ...
- Nginx-进程模型
1.整体框架 正常执行起来的Nginx有很多进程,有master_process和worker_process进程,master_process是监控进程即主线程,worker_process是工作进 ...