参考: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. bat批处理 批量导出多个APK的AAPT信息(含python实现)

    产品APP因架构调整,将一个APK拆分成了十几个APK,这样每次打ROM前,都要一个个核对APK的AAPT信息 一个个APK去敲命令很繁琐,想到可以用BAT批处理调用AAPT命令一次将十几个APK的A ...

  2. python中字符串是特殊的列表

    for x in range(20): print 'fizz'[x%3*4::]+'buzz'[x%5*4::]or x 这个是由 Jeff Atwood推广的一个编程练习叫FizzBuzz,问题如 ...

  3. 孤荷凌寒自学python第十七天初识Python的函数

    孤荷凌寒自学python第十七天初识Python的函数 (完整学习过程屏幕记录视频地址在文末,手写笔记在文末) 函数是能够完成指定运算并返回运算结果的代码块.是结构化编程重要的结构. 我首先发现pyt ...

  4. Wordpress 后台文章编辑区添加模板选择功能

    功能:后台编辑文章时,可以选择文章使用的模板,效果如下图: 操作步骤: <?php /** * Template Name: kbsingle full * Add by Ryan 3/18/2 ...

  5. Vue 使用Spread.js没有层级关系(隐藏与显示)

    Vue 使用Spread.js没有层级关系(隐藏与显示) 1.vue会给元素加一个监控属性.去掉 spread.js没有层级关系过半是column中值的问题

  6. Hexo添加字数统计、阅读时长

    统计插件 配置 NexT 主题默认已经集成了文章[字数统计].[阅读时长]统计功能,如果我们需要使用,只需要在主题配置文件 _config.yml 中打开 wordcount 统计功能即可.如下所示: ...

  7. aes加密码

    js地址 https://github.com/yves8888/crypto-js 下面src<!DOCTYPE html> <html lang="en"&g ...

  8. Nginx和Squid配合搭建的Web服务器前端系统

    这个架构是目前我个人觉得比较稳妥并且最方便的架构,易于多数人接受: 前端的lvs和squid,按照安装方法,把epoll打开,配置文件照搬,基本上问题不多. 这个架构和app_squid架构的区别,也 ...

  9. 可以在函数中间打点了,以分析bpf_prog_load函数为例

    可以在函数中间打点了, sudo stap -L 'process("./test").statement("func@test.c:10")' //12.10 ...

  10. 在LinkedIn的 Kafka 生态系统

    在LinkedIn的 Kafka 生态系统 Apache Kafka是一个高度可扩展的消息传递系统,作为LinkedIn的中央数据管道起着至关重要的作用. Kafka 是在2010年在LinkedIn ...