分析

又有毒瘤出题人把数学题出在树上了。

根据泰勒展开,有:

\[e^x=1+\frac{1}{1!}x+\frac{1}{2!}x^2+\frac{1}{3!}x^3+...
\]

\[sin(x)=x-\frac{1}{3!}x^3+\frac{1}{5!}x^5-...
\]

然而题目里\(x\)的位置是一个\(ax+b\)怎么办啊?直接根据二项式定理暴力展开就好了。

题目中要求支持加边删边,可以想到肯定是LCT。维护一下链上所有结点各次项系数和,查询时直接利用整条链的信息计算答案即可。

计算到\(16\)次项精度就没啥问题了。(其实是为了凑个整)

代码

#include <iostream>
#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <cmath>
#include <cctype>
#include <algorithm>
#define rin(i,a,b) for(int i=(a);i<=(b);i++)
#define rec(i,a,b) for(int i=(a);i>=(b);i--)
#define trav(i,a) for(int i=head[(a)];i;i=e[i].nxt)
typedef long long LL;
using std::cin;
using std::cout;
using std::endl; inline int read(){
int x=0,f=1;char ch=getchar();
while(ch<'0'||ch>'9'){if(ch=='-')f=-1;ch=getchar();}
while(ch>='0'&&ch<='9'){x=(x<<3)+(x<<1)+ch-'0';ch=getchar();}
return x*f;
} const int MAXN=100005;
const int MAXM=200005;
int n,m,top,sta[MAXN];
char opt[15];
double fac[20],c[20][20],powk[20],powb[20];
struct lct{
int fa,ch[2];
int opt;
double k,b;
double v[20];
double sum[20];
bool tag;
}a[MAXN]; inline void pre_process(){
fac[0]=1;
rin(i,1,16) fac[i]=fac[i-1]*i;
c[0][0]=1;
rin(i,1,16) rin(j,0,i){
c[i][j]=c[i-1][j];
if(j) c[i][j]+=c[i-1][j-1];
}
} #define lc a[x].ch[0]
#define rc a[x].ch[1]
inline bool isroot(int x){
return a[a[x].fa].ch[0]!=x&&a[a[x].fa].ch[1]!=x;
} inline void pushup(int x){
rin(i,0,16) a[x].sum[i]=a[x].v[i]+a[lc].sum[i]+a[rc].sum[i];
} inline void pushr(int x){
std::swap(lc,rc);
a[x].tag^=1;
} inline void pushdown(int x){
if(!a[x].tag) return;
if(lc) pushr(lc);
if(rc) pushr(rc);
a[x].tag=0;
} inline void info(int x){
memset(a[x].v,0,sizeof a[x].v);
if(a[x].opt==1){
powk[0]=powb[0]=1;
rin(i,1,16){
powk[i]=powk[i-1]*a[x].k;
powb[i]=powb[i-1]*a[x].b;
}
int pn=1;
for(int i=1;i<=16;i+=2){
rin(j,0,i){
a[x].v[j]+=pn*powk[j]*powb[i-j]*c[i][j]/fac[i];
}
pn=-pn;
}
}
else if(a[x].opt==2){
powk[0]=powb[0]=1;
rin(i,1,16){
powk[i]=powk[i-1]*a[x].k;
powb[i]=powb[i-1]*a[x].b;
}
rin(i,0,16){
rin(j,0,i){
a[x].v[j]+=powk[j]*powb[i-j]*c[i][j]/fac[i];
}
}
}
else{
a[x].v[1]=a[x].k;
a[x].v[0]=a[x].b;
}
pushup(x);
} inline void rotate(int x){
int y=a[x].fa,z=a[y].fa,f=(a[y].ch[1]==x),g=a[x].ch[f^1];
if(!isroot(y)) a[z].ch[a[z].ch[1]==y]=x;
a[x].ch[f^1]=y;
a[y].ch[f]=g;
if(g) a[g].fa=y;
a[y].fa=x;
a[x].fa=z;
pushup(y);
} inline void splay(int x){
int y=x,z=0;
top=1,sta[1]=y;
while(!isroot(y)) sta[++top]=y=a[y].fa;
while(top) pushdown(sta[top--]);
while(!isroot(x)){
y=a[x].fa,z=a[y].fa;
if(!isroot(y)){
if((a[y].ch[0]==x)==(a[z].ch[0]==y)) rotate(y);
else rotate(x);
}
rotate(x);
}
pushup(x);
} inline void access(int x){
for(int y=0;x;x=a[y=x].fa){
splay(x);
rc=y;
pushup(x);
}
} inline void makeroot(int x){
access(x);
splay(x);
pushr(x);
} inline int findroot(int x){
access(x);
splay(x);
while(lc) x=lc;
return x;
} inline void split(int x,int y){
makeroot(x);
access(y);
splay(y);
} inline void link(int x,int y){
makeroot(x);
a[x].fa=y;
} inline void cut(int x,int y){
split(x,y);
a[x].fa=0;
a[y].ch[0]=0;
pushup(y);
} inline double query(int x,int y,double iq){
split(x,y);
double tt=1,ret=0;
rin(i,0,16){
ret+=a[y].sum[i]*tt;
tt*=iq;
}
return ret;
}
#undef lc
#undef rc int main(){
pre_process();
n=read(),m=read();
scanf("%s",opt+1);
rin(i,1,n){
a[i].opt=read();
scanf("%lf%lf",&a[i].k,&a[i].b);
info(i);
}
while(m--){
scanf("%s",opt+1);
if(opt[1]=='a'){
int x=read()+1,y=read()+1;
link(x,y);
}
else if(opt[1]=='d'){
int x=read()+1,y=read()+1;
cut(x,y);
}
else if(opt[1]=='m'){
int x=read()+1;a[x].opt=read();
scanf("%lf%lf",&a[x].k,&a[x].b);
getchar();
splay(x);
info(x);
}
else{
int x=read()+1,y=read()+1;
double iq;scanf("%lf",&iq);
getchar();
if(findroot(x)!=findroot(y)){
printf("unreachable\n");
continue;
}
printf("%.8le\n",query(x,y,iq));
}
}
return 0;
}

[LOJ2289][THUWC2017]在美妙的数学王国中畅游:Link-Cut Tree+泰勒展开的更多相关文章

  1. 【BZOJ5020】【THUWC2017】在美妙的数学王国中畅游(Link-Cut Tree,组合数学)

    [BZOJ5020][THUWC2017]在美妙的数学王国中畅游(Link-Cut Tree,组合数学) 题解 Description 数字和数学规律主宰着这个世界. 机器的运转, 生命的消长, 宇宙 ...

  2. [THUWC2017]在美妙的数学王国中畅游

    [THUWC2017]在美妙的数学王国中畅游 e和sin信息不能直接合并 泰勒展开,大于21次太小,认为是0,保留前21次多项式即可 然后就把e,sin ,kx+b都变成多项式了,pushup合并 上 ...

  3. [BZOJ5020][THUWC2017]在美妙的数学王国中畅游(LCT)

    5020: [THUWC 2017]在美妙的数学王国中畅游 Time Limit: 80 Sec  Memory Limit: 512 MBSec  Special JudgeSubmit: 323  ...

  4. 并不对劲的bzoj5020:loj2289:p4546:[THUWC2017]在美妙的数学王国中畅游

    题目大意 有一个n(\(n\leq 10^5\))个点的森林,每个点\(u\)上有个函数\(f_u(x)\),是形如\(ax+b\)或\(e^{ax+b}\)或\(sin(ax+b)\)的函数,保证当 ...

  5. Luogu4546 THUWC2017 在美妙的数学王国中畅游 LCT、泰勒展开

    传送门 题意:反正就是一堆操作 LCT总是和玄学东西放在一起我们不妨令$x_0=0.5$(其实取什么都是一样的,但是最好取在$[0,1]$的范围内),将其代入给出的式子,我们得到的$f(x)$的式子就 ...

  6. [THUWC2017]在美妙的数学王国中畅游 LCT+泰勒展开+求导

    p.s. 复合函数求导时千万不能先带值,再求导. 一定要先将符合函数按照求导的规则展开,再带值. 设 $f(x)=g(h(x))$,则对 $f(x)$ 求导: $f'(x)=h'(x)g'(h(x)) ...

  7. 题解 洛谷 P4546 【[THUWC2017]在美妙的数学王国中畅游】

    首先发现有连边和删边的操作,所以我们肯定要用\(LCT\)来进行维护. 接下来考虑如何进行\(LCT\)上的信息合并. \(f=1\),则函数为\(f(x)=sin(ax+b)\) \(f=2\),则 ...

  8. Luogu P4546 [THUWC2017]在美妙的数学王国中畅游

    题意 题意奇奇怪怪,这里就不写了. \(\texttt{Data Range:}1\leq n\leq 10^5,1\leq m\leq 2\times 10^5\) 题解 为什么你们都是卡在数学方面 ...

  9. 洛谷P4546 [THUWC2017]在美妙的数学王国中畅游 [LCT,泰勒展开]

    传送门 毒瘤出题人卡精度-- 思路 看到森林里加边删边,容易想到LCT. 然而LCT上似乎很难实现往一条链里代一个数进去求和,怎么办呢? 善良的出题人在下方给了提示:把奇怪的函数泰勒展开搞成多项式,就 ...

随机推荐

  1. 【Linux开发】Linux下jpeglib库的安装详解

    Linux下jpeglib库的安装详解 首先要下载所需的库压缩包:jpegsrc.v6b.tar.gz或 jpegsrc.v8b.tar.gz 然后将下载的压缩包随便放在和解压到你喜欢的地方. # t ...

  2. 二、Zabbix-zabbix server部署-LNMP

    部署Zabbix server主要分为两部分(软件基本都是yum安装,不要问我为什么不用源码,因为没有必须用源码的需求) 一.部署LNMP/LAMP环境,已提供zabbix的界面展示,已经zabbix ...

  3. 关于android工具链

    1 android sdk platform tools 同android platform交互的工具,包括adb.fastboot和systrace. 2 sdk build tools 用于bui ...

  4. CentOS7使用集群同步脚本对配置文件同步分发

    1.介绍 使用集群同步脚本对配置文件同步分发 2.操作 1)在/root目录下创建bin目录,并在bin目录下创建文件xsync,文件内容如下: [root@hadoop101 ~]$ mkdir b ...

  5. CentOS7中MySQL跨机器数据迁移

    1.概况 在CentOS7环境下,使用命令方式将MySQL数据从源端主机迁移到目标端主机上. 2.迁移全部数据库 1)源端备份: [root@hadoop102 /]# mysqldump -u ro ...

  6. 使用git命令删除branch

    使用git删除server上的一个branch注意事项: 1. 使用命令:git push origin –delete 分支名 (分支名称需要去掉origin,如果有),   git branch ...

  7. 区间动态规划 矩阵连乘 Medium

    The multiplication puzzle is played with a row of cards, each containing a single positive integer. ...

  8. MySQL: InnoDB的并发控制,锁,事务模型

    一.并发控制 为啥要进行并发控制? 并发的任务对同一个临界资源进行操作,如果不采取措施,可能导致不一致,故必须进行并发控制(Concurrency Control). 技术上,通常如何进行并发控制? ...

  9. vue手动制作地址选择器

    方法一:4级地址选择器(基于elementui   Cascader 级联选择器) 推荐 效果图: 组件源码: <template> <div class="select- ...

  10. Python 项目转化为so文件

    思路是先将py转换为c代码,然后编译c为so文件,所以要安装以下内容: python 安装:cython pip install cython linux 安装:python-devel,gcc yu ...