bzoj5020: [THUWC 2017]在美妙的数学王国中畅游
Description
Input
Output
考虑到函数定义域都是[0,1],维护函数在0.5处的泰勒展开的前几项,可以达到精度要求,然后就是经典的lct操作了
#include<bits/stdc++.h>
typedef double ld;
const int K=,N=1e5+;
ld fiv[K];
struct node{
node*f,*c[];
int rv;
ld v[K],s[K];
void revs(){
if(this)rv^=,std::swap(c[],c[]);
}
void up(ld*a){
for(int i=;i<K;++i)s[i]+=a[i];
}
void up(){
for(int i=;i<K;++i)s[i]=v[i];
if(c[])up(c[]->s);
if(c[])up(c[]->s);
}
void dn(){
if(rv){
c[]->revs();
c[]->revs();
rv=;
}
}
bool nrt(){
return f&&(f->c[]==this||f->c[]==this);
}
int wc(){
return this==f->c[];
}
ld cal(ld x){
x-=0.5;
ld y=;
for(int i=K-;i>=;--i)y=y*x+s[i];
return y;
}
void init(int tp,ld a,ld b){
b+=a/;
if(tp==){
double z[]={sin(b),cos(b),-sin(b),-cos(b)},pa=;
for(int i=;i<K;++i)v[i]=z[i%]*pa*fiv[i],pa*=a;
}else if(tp==){
double z=exp(b);
for(int i=;i<K;++i)v[i]=z*fiv[i],z*=a;
}else if(tp==){
v[]=b,v[]=a;
for(int i=;i<K;++i)v[i]=;
}
up();
}
}ns[N],*ss[N];
int ssp=;
void sc(node*x,int d,node*y){
if(x->c[d]=y)y->f=x;
}
void rot(node*x){
node*f=x->f,*g=f->f;
int d=x->wc();
if(f->nrt())g->c[f->wc()]=x;
x->f=g;
sc(f,d,x->c[d^]);
sc(x,d^,f);
f->up();
}
void sp(node*x){
for(node*a=x;(ss[ssp++]=a)->nrt();a=a->f);
while(ssp)ss[--ssp]->dn();
while(x->nrt()){
node*f=x->f;
if(f->nrt())rot(x->wc()==f->wc()?f:x);
rot(x);
}
x->up();
}
void acs(node*x){for(node*y=;x;sp(x),x->c[]=y,x->up(),y=x,x=x->f);}
void mrt(node*x){acs(x);sp(x);x->revs();}
void lk(node*x,node*y){mrt(x);x->f=y;}
void get(node*x,node*y){mrt(x),acs(y),sp(y);}
void ct(node*x,node*y){get(x,y);x->f=y->c[]=;y->up();}
int n,m,tp;
ld a,b;
int main(){
for(int i=fiv[]=;i<K;++i)fiv[i]=fiv[i-]/i;
scanf("%d%d%*s",&n,&m);
for(int i=;i<n;++i){
scanf("%d%lf%lf",&tp,&a,&b);
ns[i].init(tp,a,b);
}
while(m--){
char op[];
int x,y;
scanf("%s%d%d",op,&x,&y);
if(op[]=='a')lk(ns+x,ns+y);
else if(op[]=='d')ct(ns+x,ns+y);
else if(op[]=='t'){
scanf("%lf",&a);
get(ns+x,ns+y);
node*w=ns+x;
while(w->f)w=w->f;
if(w==ns+y)printf("%.8e\n",w->cal(a));
else puts("unreachable");
sp(ns+x);
}else{
scanf("%lf%lf",&a,&b);
sp(ns+x);
ns[x].init(y,a,b);
}
}
return ;
}
bzoj5020: [THUWC 2017]在美妙的数学王国中畅游的更多相关文章
- BZOJ5020: [THUWC 2017]在美妙的数学王国中畅游(LCT,泰勒展开,二项式定理)
Description 数字和数学规律主宰着这个世界. 机器的运转, 生命的消长, 宇宙的进程, 这些神秘而又美妙的过程无不可以用数学的语言展现出来. 这印证了一句古老的名言: ...
- BZOJ5020 [THUWC 2017]在美妙的数学王国中畅游LCT
题意很明显是要用LCT来维护森林 难点在于如何处理函数之间的关系 我们可以根据题目给的提示关于泰勒展开的式子 将三种函数变成泰勒展开的形式 因为$x∈[0,1]$ 所以我们可以将三个函数在$x_0=0 ...
- 【BZOJ5020】[THUWC 2017]在美妙的数学王国中畅游 泰勒展开+LCT
[BZOJ5020][THUWC 2017]在美妙的数学王国中畅游 Description 数字和数学规律主宰着这个世界. 机器的运转, 生命的消长, 宇宙的进程, 这些神秘而又美妙的过程无不可以用数 ...
- bzoj5020 & loj2289 [THUWC 2017]在美妙的数学王国中畅游 LCT + 泰勒展开
题目传送门 https://lydsy.com/JudgeOnline/problem.php?id=5020 https://loj.ac/problem/2289 题解 这个 appear 和 d ...
- [THUWC 2017]在美妙的数学王国中畅游
bzoj5020 \[答案误差只要小于 10^{-7}\] 题解 Taylor展开式: \[若f(x)的n阶导数在[a, b]内连续,则f(x)在x_{0}\in[a, b]可表示为\] \[f(x) ...
- 解题:THUWC 2017 在美妙的数学王国中畅游
题面 _“数字和数学规律主宰着这个世界.”_ 在 @i207M 帮助下折腾了半天终于搞懂了导数和泰勒展开,引用某学长在考场上的感受:感觉整个人都泰勒展开了 显然是个奇奇怪怪的东西套上LCT,发现直接维 ...
- bzoj 5020(洛谷4546) [THUWC 2017]在美妙的数学王国中畅游——LCT+泰勒展开
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=5020 https://www.luogu.org/problemnew/show/P4546 ...
- loj2289 [THUWC 2017]在美妙的数学王国中畅游(LCT+Taylor展开)
link 题目大意: 你需要维护一个树 每个点都有个sin(ax+b)或exp(ax+b)或ax+b 你需要维护一些操作:连边.删边.修改某个点的初等函数.询问某条树链上所有函数带入某个值后权值和或不 ...
- bzoj 5020: [THUWC 2017]在美妙的数学王国中畅游【泰勒展开+LCT】
参考:https://www.cnblogs.com/CQzhangyu/p/7500328.html --其实理解了泰勒展开之后就是水题呢可是我还是用了两天时间来搞懂啊 泰勒展开是到正无穷的,但是因 ...
随机推荐
- 利用SIFT进行特征匹配
SIFT算法是一种基于尺度空间的算法.利用SIFT提取出的特征点对旋转.尺度变化.亮度变化具有不变性,对视角变化.仿射变换.噪声也有一定的稳定性. SIFT实现特征的匹配主要包括四个步骤: 提取特征点 ...
- JDK8 特性详解
Base64 对Base64编码的支持已经被加入到Java 8官方库中,这样不需要使用第三方库就可以进行Base64编码,例子代码如下: package com.cn.yunliu.jdk8; imp ...
- weixin-java-mp集成微信公众号自带客服功能
电脑端登录公众号管理后台,[添加功能插件]开通客服功能,输入"人工客服"接入客服热线 底部有我的微信二维码,如有问题,可加好友进行技术交流! weixi ...
- java-接口的成员特点
1.成员变量: - 只能是常量,并且是静态的.公共的. - 默认修饰符:public static final - 建议:自己手动给出. 2.构造方法:接口没有构造方法. 3.成员方法: - 只能是抽 ...
- django HttpResponse的用法
一.传json字典 def back_json(rquest): #JsonResponse父类是HttpResponse,原码里调用了json.dumps() from django.http im ...
- 10 HashMap,Map.Entry,LinkedHashMap,TreeMap,Hashtable,Collections类
Map集合的功能概述 添加功能 * V put(K key,V value):添加元素. * 如果键是第一次存储,就直接存储元素,返回null * 如果键不 ...
- PS学习之动态表情制作
准备素材 1. 2. 3. 4. 最后效果图: 在PS中打开四个图片 另外新建一个文件 用魔棒工具抠图 点击白色位置 右键选择反向 右键人物 选择拷贝的图层 重复,将四个图片扣好 拖到新建的文件里 如 ...
- canvas 使用 isPointInPath() 判断鼠标位置是否在绘制的元素上
canvas 里绘制的图形不是一个实体 DOM,所以要给每个绘制的图形添加事件操作比给 DOM 添加事件要复杂很多. 所以,我们需要使用一个 canvas 的 isPointInPath(x, y) ...
- 如何对oracle数据库进行监控检查
sqlplus '/as sysdba' 手动生成一个oracle数据库的快照 execute dbbms_workload_repository.create_snapshot(); 执行自动工作负 ...
- centos配置apache的https服务
因为公司要开发微信小程序,由于小程序比较特殊,需要https服务,所以就研究了下apache的https服务了,大致过程如下: 1.向证书机构申请https证书,会得到证书和私钥 2.安装apache ...