bzoj 5020: [THUWC 2017]在美妙的数学王国中畅游【泰勒展开+LCT】
参考:https://www.cnblogs.com/CQzhangyu/p/7500328.html
……其实理解了泰勒展开之后就是水题呢可是我还是用了两天时间来搞懂啊
泰勒展开是到正无穷的,但是因为精度问题,所以一般展开十几项就可以(这里展开了17项)。以下是公式:
\]
\]
然后用二项式定理把x替换成ax+b:
\]
\]
展开的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】的更多相关文章
- 【BZOJ5020】[THUWC 2017]在美妙的数学王国中畅游 泰勒展开+LCT
[BZOJ5020][THUWC 2017]在美妙的数学王国中畅游 Description 数字和数学规律主宰着这个世界. 机器的运转, 生命的消长, 宇宙的进程, 这些神秘而又美妙的过程无不可以用数 ...
- 5020: [THUWC 2017]在美妙的数学王国中畅游
传送门 当年听llj讲的时候觉得这简直是个不可做的神题. 现在看来并不是很神,可能是我已经被剧透了的缘故... 一开始以为是函数套函数,懵蔽了好久,结果只是求和 被剧透了泰勒展开就比较水了..只要你不 ...
- BZOJ5020: [THUWC 2017]在美妙的数学王国中畅游(LCT,泰勒展开,二项式定理)
Description 数字和数学规律主宰着这个世界. 机器的运转, 生命的消长, 宇宙的进程, 这些神秘而又美妙的过程无不可以用数学的语言展现出来. 这印证了一句古老的名言: ...
- bzoj5020: [THUWC 2017]在美妙的数学王国中畅游
Description 数学王国中,每个人的智商可以用一个属于 [0,1]的实数表示.数学王国中有 n 个城市,编号从 0 到 n−1 ,这些城市由若干座魔法桥连接.每个城市的中心都有一个魔法球,每个 ...
- bzoj 5020(洛谷4546) [THUWC 2017]在美妙的数学王国中畅游——LCT+泰勒展开
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=5020 https://www.luogu.org/problemnew/show/P4546 ...
- 解题:THUWC 2017 在美妙的数学王国中畅游
题面 _“数字和数学规律主宰着这个世界.”_ 在 @i207M 帮助下折腾了半天终于搞懂了导数和泰勒展开,引用某学长在考场上的感受:感觉整个人都泰勒展开了 显然是个奇奇怪怪的东西套上LCT,发现直接维 ...
- 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) ...
- BZOJ5020 [THUWC 2017]在美妙的数学王国中畅游LCT
题意很明显是要用LCT来维护森林 难点在于如何处理函数之间的关系 我们可以根据题目给的提示关于泰勒展开的式子 将三种函数变成泰勒展开的形式 因为$x∈[0,1]$ 所以我们可以将三个函数在$x_0=0 ...
随机推荐
- python 学习分享-实战篇高级的ftp
#server代码 import socketserver,os,hashlib Base_paht = os.path.dirname(os.path.dirname(os.path.abspath ...
- 孤荷凌寒自学python第六十五天学习mongoDB的基本操作并进行简单封装4
孤荷凌寒自学python第六十五天学习mongoDB的基本操作并进行简单封装4 (完整学习过程屏幕记录视频地址在文末) 今天是学习mongoDB数据库的第十一天. 今天继续学习mongoDB的简单操作 ...
- 融合模型Aggregation
从一堆弱分类器融合得到强分类器. 比如假设现在你只能水平或竖直线分割,那么无论如何都分不好,但是假设组合三次分割,就会得到如图所示的一个较好的分割线. 再比如,PLA 融合后有large margin ...
- winform 路径
System.AppDomain.CurrentDomain.BaseDirectory d:\project\bin\release\
- C++寒假学习计划
课程 中国大学mooc西北工业大学c++程序设计 理由 本课程有48节,章节分类清晰,由许多小知识块组成,条例清晰便于学习,由基础开始,由浅入深,适合我这种小白. 计划 从2.8号至2.28除去2.1 ...
- GridView与ListView冲突
由于GridView与listView都是继承自ScrollView,所以两个控件放在一起时需要重写控件方法 public class MyGridView extends GridView{ ...
- Vue.js入门(一)
<!DOCTYPE html> <html> <head> <meta charset="utf-8"/> <meta htt ...
- PHP面向对象单例模式(懒汉式)
知识点: 一.三私一公: ①.私有静态属性,又来储存生成的唯一对象 ②.私有构造函数 ③.私有克隆函数,防止克隆——clone ④.公共静态方法,用来访问静态属性储存的对象,如果没有对象,则生成此单例 ...
- P3141 [USACO16FEB]围栏Fenced In_Platinum
题目描述 Farmer John has realized that many of his cows are strangely agoraphobic (being fearful of larg ...
- linux下对/sys/class/gpio中的gpio的控制 (转)
在嵌入式设备中对GPIO的操作是最基本的操作.一般的做法是写一个单独驱动程序,网上大多数的例子都是这样的.其实linux下面有一个通用的GPIO操作接口,那就是我要介绍的 “/sys/clas ...