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 ...
随机推荐
- linux_shell基础-变量、数组、运算符
#!/bin/bash# echo 'hello world'# name='http://www.baidu.com'# for file in $(ls ./); do# echo "t ...
- SQLite3中dos命令下退出"...>"状态的方法
今天在看Android中SQLite,跟着书上一步一步走,在dos中敲命令时候不小心敲错了,命令行就会突然变成”…>”这样的,本来是”sqlite>”的,然后接下来后面的就没办法在继续操作 ...
- Python网络编程(http协议,IO多路复用、select内核监听)
前言: 什么是IO? 分为IO设备和IO接口两个部分 如Linux系统,I/O操作可以有多种方式 比如DIO(DirectI/O) AIO(AsynchronousI/O异步I/O) Memory-M ...
- Tensorflow实现LSTM识别MINIST
import tensorflow as tf import numpy as np from tensorflow.contrib import rnn from tensorflow.exampl ...
- Eclipse下使用SVN插件从服务器获取工程
1.打开Eclipse 4.4,在Eclipse里打开SVN资源库窗口:点击菜单window-->show view-->other:然后再弹出窗口展开SVN节点,选择SVN资源库 2 ...
- css 外边距,内边距的使用
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- solr集群搭建(复制)
Solr集群的搭建以及使用(内涵zookeeper集群的搭建指南) 1 什么是SolrCloud SolrCloud(solr 云)是Solr提供的分布式搜索方案,当你需要大规模,容错,分布式索引 ...
- KindleEditor insertfile初始化多个
KindEditor.ready(function (K) { var editor = K.editor({ allowFileManager: true }); K('#insertfile'). ...
- jQuery中Ajax的属性设置
1.全局设置为同步 $.ajaxSetup({ async: false });
- JS设置、获取DOM自定义属性
jQuery方式 // 获取 $('#test').attr('mydata'); // 设置 $('#test').attr('mydata','data-content'); // 移除 $('# ...