题解【[Ynoi2012]NOIP2015洋溢着希望】
\]
第二道 Ynoi 的题,纪念一下。
这可能是我唯一可以自己做的 Ynoi 题了。
\]
维护一个长度为 \(n\) 的数列 \(a\),支持两种操作:
1 l r v
将 \(a_l,a_{l+1},...,a_r\) 分别加上 \(v\)2 l r
询问 \(\sum\limits_{i=l}\limits^{r}\sin(a_i)\) 。
\]
区间修改和区间查询使我们想到线段树。
尝试在线段树上维护一个区间 \(\sin\) 和。
我们发现,区间加的时候,原来的 \(\sin(a_i)\) 都变成了 \(\sin(a_i+v)\) ,不易直接维护。
考虑这两个公式:
\[\sin(a+v)=\sin a\cos v+\cos a\sin v
\]\[\cos(a+v)=\cos a\cos v-\sin a \sin v
\]显然区间加将区间 \([l,r]\) 的 \(\sin\) 和从 \(\sum\limits_{i=l}\limits^{r}\sin(a_i)\) 变成了 \(\sum\limits_{i=l}\limits^{r}\sin(a_i+v)\) ,进一步,有:
\[\sum\limits_{i=l}\limits^{r}\sin a_i \cos v+ \cos a_i \sin v
\]
\]
- 于是我们可以再维护一个区间 \(\cos\) 和, 区间加对 \([l,r]\) 的 \(\cos\) 和的影响为:
\]
- 套用上述公式更新区间 \(\sin\) 和以及区间 \(\cos\) 和即可,记得打好标记。
\]
#include<cstdio>
#include<cmath>
#define RI register int
using namespace std;
namespace IO
{
static char buf[1<<20],*fs,*ft;
inline char gc()
{
if(fs==ft)
{
ft=(fs=buf)+fread(buf,1,1<<20,stdin);
if(fs==ft)return EOF;
}
return *fs++;
}
#define gc() getchar()
inline int read()
{
int x=0,f=1;char s=gc();
while(s<'0'||s>'9'){if(s=='-')f=-f;s=gc();}
while(s>='0'&&s<='9'){x=x*10+s-'0';s=gc();}
return x*f;
}
}using IO::read;
const int N=200100;
int n,m;
int a[N];
struct SegmentTree{
int l,r;
double sinv,cosv;
long long tag;
}t[N*4];
void upd(int p)
{
t[p].sinv=t[p*2].sinv+t[p*2+1].sinv;
t[p].cosv=t[p*2].cosv+t[p*2+1].cosv;
}
void spread(int p)
{
if(t[p].tag)
{
double sina,cosa,sinx=sin(t[p].tag),cosx=cos(t[p].tag);
sina=t[p*2].sinv,cosa=t[p*2].cosv;
t[p*2].sinv=sina*cosx+cosa*sinx;
t[p*2].cosv=cosa*cosx-sina*sinx;
sina=t[p*2+1].sinv,cosa=t[p*2+1].cosv;
t[p*2+1].sinv=sina*cosx+cosa*sinx;
t[p*2+1].cosv=cosa*cosx-sina*sinx;
t[p*2].tag+=t[p].tag;
t[p*2+1].tag+=t[p].tag;
t[p].tag=0;
}
}
void build(int p,int l,int r)
{
t[p].l=l,t[p].r=r;
if(l==r)
{
t[p].sinv=sin(a[l]),t[p].cosv=cos(a[l]);
return;
}
int mid=(l+r)/2;
build(p*2,l,mid);
build(p*2+1,mid+1,r);
upd(p);
}
void change(int p,int l,int r,int val)
{
if(l<=t[p].l&&t[p].r<=r)
{
double sina=t[p].sinv,cosa=t[p].cosv,sinx=sin(val),cosx=cos(val);
t[p].sinv=sina*cosx+cosa*sinx;
t[p].cosv=cosa*cosx-sina*sinx;
t[p].tag+=val;
return;
}
spread(p);
int mid=(t[p].l+t[p].r)/2;
if(l<=mid)
change(p*2,l,r,val);
if(mid<r)
change(p*2+1,l,r,val);
upd(p);
}
double ask(int p,int l,int r)
{
if(l<=t[p].l&&t[p].r<=r)return t[p].sinv;
spread(p);
int mid=(t[p].l+t[p].r)/2;
double val=0;
if(l<=mid)
val+=ask(p*2,l,r);
if(mid<r)
val+=ask(p*2+1,l,r);
return val;
}
int main()
{
n=read();
for(RI i=1;i<=n;i++)
a[i]=read();
build(1,1,n);
m=read();
while(m--)
{
int opt=read(),l=read(),r=read();
switch(opt)
{
case 1:{
double val; scanf("%lf",&val);
change(1,l,r,val);
break;
}
case 2:{
printf("%.1lf\n",ask(1,l,r));
break;
}
}
}
return 0;
}
\]
题解【[Ynoi2012]NOIP2015洋溢着希望】的更多相关文章
- 【题解】NOIP2015提高组 复赛
[题解]NOIP2015提高组 复赛 传送门: 神奇的幻方 \([P2615]\) 信息传递 \([P2661]\) 斗地主 \([P2668]\) 跳石头 \([P2678]\) 子串 \([P26 ...
- [题解+总结]NOIP2015模拟题2
// 此博文为迁移而来,写于2015年7月22日,不代表本人现在的观点与看法.原始地址:http://blog.sina.com.cn/s/blog_6022c4720102w72i.html 1.总 ...
- 【题解】NOIP2015推销员
……普及组的题目都做不出来……(:´д`)ゞ……再这样下去要退役了啊…… 不过不管怎样感觉这题还是蛮好的,也要记录一下下~ 我们注意到数据的范围,n 是 1e5, 又有 1e5组询问,暴力大概是 \( ...
- 《如何在大学里脱颖而出(How to Win at College)》读书笔记
<如何在大学里脱颖而出(How to Win at College)>读书笔记 图书简介 中文版: 英文版: 作者卡尔·纽波特(Cal Newport)于 2004 年6月以优等生荣誉学会 ...
- SDOI2017 BZOJ 4820 硬币游戏 解题报告
写在前面 此题网上存在大量题解,但本人太菜了,看了不下10篇均未看懂,只好自己冷静分析了.本文将严格详细地论述算法(避免一切意会和玄学),因此可能会比其它题解更加理论化一些,希望能对像我一样看了其它题 ...
- 动态删边SPFA: [HNOI2014]道路堵塞
[HNOI2014]道路堵塞 题目描述 $A$ 国有 $N$座城市,依次标为$1$到$N$.同时,在这$N$座城市间有$M$条单向道路,每条道路的长度是一个正整数.现在,$A$国交通部指定了一条从城市 ...
- 暑假集训D15总结
考试 日常爆炸= = T1数据背锅,回天乏力 推了两个小时的T2竟然莫名RE,我也是服了 T3考试时就没读懂题,做个鬼啊 今天一直在写某奇怪的技术贴,竟然没有写题解(手动滑稽) 希望明天不要乱炸吧 博 ...
- LeetCode 31:递归、回溯、八皇后、全排列一篇文章全讲清楚
本文始发于个人公众号:TechFlow,原创不易,求个关注 今天我们讲的是LeetCode的31题,这是一道非常经典的问题,经常会在面试当中遇到.在今天的文章当中除了关于题目的分析和解答之外,我们还会 ...
- [NOIP2015 提高组] 运输计划题解
题目链接:P2680 [NOIP2015 提高组] 运输计划 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn) 看了好长时间题解才终于懂的,有关lca和二分答案的题解解释的不详细,一时 ...
随机推荐
- ASP.NET Core Web API 路由的有效使用
ROUTING 在 .NET Core Web API 项目中,我们应该使用属性路由代替传统路由,这是因为属性路由可以帮助我们匹配路由参数名称与 Action 内的实际参数方法.另一个原因是路由参数的 ...
- 常用的MQ命令
删除队列管理器 dltmqm QmgrName 启动队列管理器 strmqm QmgrName 如果是启动默认的队列管理器,可以不带其名字 停止队列管理器 endmqm QmgrName 受控停止 e ...
- python 实现 md文档自动编号
目录 1. 原理 2. 运行方法 3. 效果 4. 代码 1. 原理 正则匹配对相应字符串进行替换 2. 运行方法 python md_convert.py [a.md, b.md,...] # 转换 ...
- [坑] js indexOf is not a function
今天写js的时候,本来没有问题的代码突然出现了问题,就是本来下拉框里面在更新之后会出现内容的 但是并没有出现内容,按下F12 查看了Console之后发现确实是接收到了数据,但是却也报错了 内容是 我 ...
- Logarithmic-Trigonometric积分系列(一)
\[\Large\displaystyle \int_{0}^{\frac{\pi }{2}}x^{2}\ln\left ( \sin x \right )\ln\left ( \cos x \rig ...
- 1042B. Vitamins
Berland shop sells nn kinds of juices. Each juice has its price cici. Each juice includes some set o ...
- 论STA | SOCV / POCV 之 variation (2)
芯片制造涉及到许多复杂重复的过程,如:光刻.蚀刻.离子注入.扩散.退火.而且都是原子级操作,尽管控制非常严格,但偏差不可避免. 工艺偏差会导致芯片物理参数偏差,如:线宽.沟道掺杂浓度.线厚.临界尺寸. ...
- jquery 获取 父级 iframe 里的控件对象
window.parent.document.getElementsByTagName('iframe')[0].contentWindow.document.getElementById('id')
- jsTree的checkbox默认选中和隐藏
jstree复选框自定义显示隐藏和初始化默认选中 首先需要配置 Checkbox plugin "plugins" : ['checkbox'] 设置默认选中状态(checkbox ...
- 安装nodejs时提示Leaving directory
在按照标准的编译命令./configure =>make =>make install 在make的时候发生错误: ../deps/v8/src/base/platform/mutex.h ...