参考:https://www.cnblogs.com/CQzhangyu/p/7500328.html

……其实理解了泰勒展开之后就是水题呢可是我还是用了两天时间来搞懂啊

泰勒展开是到正无穷的,但是因为精度问题,所以一般展开十几项就可以(这里展开了17项)。以下是公式:

\[e^x=\sum_{i=0}^{\infty}\frac{x^i}{i!}
\]

\[sin(x)=\sum_{i=0}^{\infty}\frac{(-1)^ix^{2i+1}}{(2i+1)!}
\]

然后用二项式定理把x替换成ax+b:

\[e^{ax+b}=\sum_{i=0}^{\infty}\frac{\sum_{j=0}^{i}C_i^ja^jx^jb^{i-j}}{i!}
\]

\[sin(ax+b)=\sum_{i=0}^{\infty}\frac{(-1)^i\sum_{j=0}^{2i+1}C_i^ja^jx^jb^{2i+1-j}}{(2i+1)!}
\]

展开的17项在splay上可以直接逐项加起来,然后计算答案的时候直接乘相应的x次方即可。

#include<iostream>
#include<cstdio>
#include<cstring>
using namespace std;
const int N=1000005,D=17;
int n,m,tp[N],st[N],top;
double a[N],b[N],jc[20],y[20][20],at[20],bt[20];
char s[100];
struct qwe
{
int f,c[2],sz,lz,tp;
double v[20],s[20],a,b;
void tl()
{
int i,j,f;
memset(v,0,sizeof(v));
if(tp==1)
{
for(at[0]=bt[0]=1,i=1;i<=D;i++)
at[i]=at[i-1]*a,bt[i]=bt[i-1]*b;
for(i=1;i<=D;i+=2)
{
f=(i%4==1)?1:-1;
for(j=0;j<=i;j++)
v[j]+=f*at[j]*bt[i-j]*y[i][j]/jc[i];
}
}
else if(tp==2)//这里枚举的是2i+1
{
for(at[0]=bt[0]=1,i=1;i<=D;i++)
at[i]=at[i-1]*a,bt[i]=bt[i-1]*b;
for(i=0;i<=D;i++)
for(j=0;j<=i;j++)
v[j]+=at[j]*bt[i-j]*y[i][j]/jc[i];
}
else
v[0]=b,v[1]=a;
}
}t[N];
int read()
{
int r=0,f=1;
char p=getchar();
while(p>'9'||p<'0')
{
if(p=='-')
f=-1;
p=getchar();
}
while(p>='0'&&p<='9')
{
r=r*10+p-48;
p=getchar();
}
return r*f;
}
bool srt(int x)
{
return t[t[x].f].c[0]!=x&&t[t[x].f].c[1]!=x;
}
void ud(int x)
{
for(int i=0;i<=D;i++)
t[x].s[i]=t[t[x].c[0]].s[i]+t[t[x].c[1]].s[i]+t[x].v[i];
t[x].sz=t[t[x].c[0]].sz+t[t[x].c[1]].sz+1;
}
void pd(int x)
{
if(t[x].lz)
{
t[x].lz=0;
t[t[x].c[0]].lz^=1;
t[t[x].c[1]].lz^=1;
swap(t[x].c[0],t[x].c[1]);
}
}
void updata(int x)
{
if(!srt(x)) updata(t[x].f);
pd(x);
}
void zhuan(int x)
{
int l,r,y=t[x].f,z=t[y].f;
if(t[y].c[0]==x)
l=0;
else
l=1;
r=l^1;
if(!srt(y))
{
if(t[z].c[0]==y)
t[z].c[0]=x;
else
t[z].c[1]=x;
}
t[x].f=z;t[y].f=x;
t[t[x].c[r]].f=y;
t[y].c[l]=t[x].c[r];
t[x].c[r]=y;
ud(y);// ud(x);
}
void splay(int x)
{//cout<<"splay"<<x<<endl;
top=0;
st[++top]=x;
for(int i=x;!srt(i);i=t[i].f)
st[++top]=t[i].f;
while(top)
pd(st[top--]);
while(!srt(x))
{
int y=t[x].f,z=t[y].f;
if(!srt(y))
{
if((t[y].c[0]==x)^(t[z].c[0]==y))
zhuan(x);
// else
// zhuan(y);
}
zhuan(x);
}
ud(x);
}
void acc(int x)
{//cout<<"acc"<<x<<endl;
for(int i=0;x;i=x,x=t[x].f)
{//cout<<"foracc"<<x<<endl;
splay(x);
t[x].c[1]=i;
ud(x);
}
}
int zhao(int x)
{
while(t[x].f)
x=t[x].f;
return x;
acc(x);
}
void mkrt(int x)
{
acc(x);
splay(x);
t[x].lz^=1;
}
void lk(int x,int y)
{
mkrt(x);
t[x].f=y;
}
void ct(int x,int y)
{//cout<<x<<" "<<y<<endl;
mkrt(x);
acc(y);
splay(y);
if(t[y].c[0]!=x)
return;
t[x].f=0;
t[y].c[0]=0;
ud(y);
}
int main()
{
// n=read(),m=read();
scanf("%d%d%s",&n,&m,s);
jc[0]=1;
for(int i=1;i<=D;i++)
jc[i]=jc[i-1]*i;
y[0][0]=1;
for(int i=1;i<=D;i++)
{
y[i][0]=1;
for(int j=1;j<=D;j++)
y[i][j]=y[i-1][j-1]+y[i-1][j];
}
for(int i=1;i<=n;i++)
{
// t[i].tp=read();
scanf("%d%lf%lf",&t[i].tp,&t[i].a,&t[i].b);
t[i].tl();
ud(i);
}
while(m--)
{
scanf("%s",s);
if(s[0]=='a')
{
// int a=read()+1,b=read()+1;
int a,b;
scanf("%d%d",&a,&b);
lk(a+1,b+1);
}
else if(s[0]=='d')
{
// int a=read()+1,b=read()+1;
int a,b;
scanf("%d%d",&a,&b);
ct(a+1,b+1);
}
else if(s[0]=='m')
{
// int a=read()+1;
int a;
scanf("%d",&a);
a++;
splay(a);
// t[a].tp=read();
scanf("%d%lf%lf",&t[a].tp,&t[a].a,&t[a].b);
t[a].tl();
ud(a);
}
else
{
// int a=read()+1,b=read()+1;
int a,b;
double x,y,ans;
scanf("%d%d%lf",&a,&b,&x);
a++,b++;
if(zhao(a)!=zhao(b))
{
puts("unreachable");
continue;
}
y=1,ans=0;
mkrt(a);
acc(b);
splay(b);
for(int j=0;j<=D;j++,y*=x)
ans+=y*t[b].s[j];
printf("%.8le\n",ans);
}
}
return 0;
}

bzoj 5020: [THUWC 2017]在美妙的数学王国中畅游【泰勒展开+LCT】的更多相关文章

  1. 【BZOJ5020】[THUWC 2017]在美妙的数学王国中畅游 泰勒展开+LCT

    [BZOJ5020][THUWC 2017]在美妙的数学王国中畅游 Description 数字和数学规律主宰着这个世界. 机器的运转, 生命的消长, 宇宙的进程, 这些神秘而又美妙的过程无不可以用数 ...

  2. 5020: [THUWC 2017]在美妙的数学王国中畅游

    传送门 当年听llj讲的时候觉得这简直是个不可做的神题. 现在看来并不是很神,可能是我已经被剧透了的缘故... 一开始以为是函数套函数,懵蔽了好久,结果只是求和 被剧透了泰勒展开就比较水了..只要你不 ...

  3. BZOJ5020: [THUWC 2017]在美妙的数学王国中畅游(LCT,泰勒展开,二项式定理)

    Description 数字和数学规律主宰着这个世界.   机器的运转,   生命的消长,   宇宙的进程,   这些神秘而又美妙的过程无不可以用数学的语言展现出来.   这印证了一句古老的名言:   ...

  4. bzoj5020: [THUWC 2017]在美妙的数学王国中畅游

    Description 数学王国中,每个人的智商可以用一个属于 [0,1]的实数表示.数学王国中有 n 个城市,编号从 0 到 n−1 ,这些城市由若干座魔法桥连接.每个城市的中心都有一个魔法球,每个 ...

  5. bzoj 5020(洛谷4546) [THUWC 2017]在美妙的数学王国中畅游——LCT+泰勒展开

    题目:https://www.lydsy.com/JudgeOnline/problem.php?id=5020 https://www.luogu.org/problemnew/show/P4546 ...

  6. 解题:THUWC 2017 在美妙的数学王国中畅游

    题面 _“数字和数学规律主宰着这个世界.”_ 在 @i207M 帮助下折腾了半天终于搞懂了导数和泰勒展开,引用某学长在考场上的感受:感觉整个人都泰勒展开了 显然是个奇奇怪怪的东西套上LCT,发现直接维 ...

  7. bzoj5020 & loj2289 [THUWC 2017]在美妙的数学王国中畅游 LCT + 泰勒展开

    题目传送门 https://lydsy.com/JudgeOnline/problem.php?id=5020 https://loj.ac/problem/2289 题解 这个 appear 和 d ...

  8. [THUWC 2017]在美妙的数学王国中畅游

    bzoj5020 \[答案误差只要小于 10^{-7}\] 题解 Taylor展开式: \[若f(x)的n阶导数在[a, b]内连续,则f(x)在x_{0}\in[a, b]可表示为\] \[f(x) ...

  9. BZOJ5020 [THUWC 2017]在美妙的数学王国中畅游LCT

    题意很明显是要用LCT来维护森林 难点在于如何处理函数之间的关系 我们可以根据题目给的提示关于泰勒展开的式子 将三种函数变成泰勒展开的形式 因为$x∈[0,1]$ 所以我们可以将三个函数在$x_0=0 ...

随机推荐

  1. python与MySQL数据库

    python与MySQL数据库 慕课网连接 我使用的软件:python2.7 + MySQL+ Navicat for MySQL + Atom 注意:你的数据库表格类型的引擎为:InnoDB :字符 ...

  2. kvm竟然抓不到kvm的tracepoint

    今天终于把kvm给搭起来了,打开了host机的tracepoint竟然一个都没有抓到,这是咋回事? 难道kvm的东西只有在启动的时候才会被抓到? 虚拟出来一块内存一块CPU,虚拟出来一个内存.感觉都好 ...

  3. 为啥shmem不回收 | drop_caches

    内核在哪里禁止对tmpfs中内存页的回收 mem.limit_in_bytes同样会触发shrink_zones过程! shrink_zones是代码中的直接内存回收路径 1.try_to_free_ ...

  4. 第八篇:python基础_8 面向对象与网络编程

    本篇内容 接口与归一化设计 多态与多态性 封装 面向对象高级 异常处理 网络编程 一. 接口与归一化设计 1.定义 (1)归一化让使用者无需关心对象的类是什么,只需要知道这些对象都具备某些功能就可以了 ...

  5. REST Web 服务(二)----JAX-RS 介绍

    1. 什么是JAX-RS? JAX-RS——Java API for RESTful Web Services,是为 Java 程序员提供的一套固定的接口(Java API),用于开发表述性状态转移( ...

  6. [洛谷P4925][1007]Scarlet的字符串不可能这么可爱

    题目大意:问字符集大小为$k$,长度为$L$的字符串,且没有长度超过$1$的回文段的个数.规定第$s(若为0则无限制)$位为$w$. 题解:懒得写了,根据是否有限制分类讨论 卡点:中途有个地方忘记取模 ...

  7. [blockchain-035]eos的部署安装智能合约

    0.参考资料 https://github.com/EOSIO/eos/wiki 1. eos的github地址 https://github.com/EOSIO/eos 2.下载eos源码 git ...

  8. (转)Ant使用例子

    文章来自:http://www.blogjava.net/feng0801/archive/2014/07/29/416297.html Ant是一个Apache基金会下的跨平台的构件工具,它可以实现 ...

  9. linux进程服务监测流程

    进程->端口监听->查阿里云端口开放->看防火墙 ps -ef | grep redis   ->netstat -an |grep redis->安全组设置端口放行规则 ...

  10. centos 7 firewall无法启动

    报错信息: [root@localhost bin]# systemctl status firewalld● firewalld.service - firewalld - dynamic fire ...