Luogu4546 THUWC2017 在美妙的数学王国中畅游 LCT、泰勒展开
题意:反正就是一堆操作
LCT总是和玄学东西放在一起
我们不妨令$x_0=0.5$(其实取什么都是一样的,但是最好取在$[0,1]$的范围内),将其代入给出的式子,我们得到的$f(x)$的式子就是一个多项式了。
然后复习一下导数:
$(Cf(x))'=Cf'(x)$($C$为常数)
$sin'(x)=cos(x),cos'(x)=-sin(x),(e^x)'=e^x,C'=0 , (ax+b)'=a$
令$g(x)=u$,则$f[g(x)]' = f'(u) \times g'(x)$
有了这些式子就可以得到给出的三种函数的任意阶导数了。
但是显然我们不能把所有项的系数都算出来。因为在比较靠后的项中,阶乘的值很大,对答案造成的贡献就会小到忽略不计,所以我们可以取前面若干项,这里我取的是前$12$项。
然后用$LCT$维护这些项的系数和,每一次询问把链拿出来直接算就行了,难题变成裸题了qwq
#include<bits/stdc++.h> #define ld long double //This code is written by Itst using namespace std; inline int read(){ ; ; char c = getchar(); while(c != EOF && !isdigit(c)){ if(c == '-') f = ; c = getchar(); } while(c != EOF && isdigit(c)){ a = (a << ) + (a << ) + (c ^ '); c = getchar(); } return f ? -a : a; } ; struct node{ ld point[] , pre[] , a , b; ] , fa , type; bool mark; }Tree[MAXN]; int N; ]; inline bool nroot(int x){ ] == x || Tree[Tree[x].fa].ch[] == x; } inline bool son(int x){ ] == x; } inline ld calc(int type , int n , ld a , ld b){ ld sum = ; switch(type){ : ){ : sum = sin(0.5 * a + b); break; : sum = cos(0.5 * a + b); break; : sum = -sin(0.5 * a + b); break; : sum = -cos(0.5 * a + b); break; } return sum * pow(a , n); : return pow(a , n) * exp(a * 0.5 + b); : switch(n){ : return a * 0.5 + b; : return a; default: ; } } } inline void pushup(int x){ ; i <= ; ++i) Tree[x].point[i] = Tree[x].pre[i] + Tree[Tree[x].ch[]].point[i] + Tree[Tree[x].ch[]].point[i]; } inline void getpre(int x){ ; i <= ; ++i) Tree[x].pre[i] = calc(Tree[x].type , i , Tree[x].a , Tree[x].b); } inline void ZigZag(int x){ bool f = son(x); ]; if(nroot(y)) Tree[z].ch[son(y)] = x; Tree[x].fa = z; Tree[x].ch[f ^ ] = y; Tree[y].fa = x; Tree[y].ch[f] = w; if(w) Tree[w].fa = y; pushup(y); pushup(x); } inline void pushdown(int x){ if(Tree[x].mark){ Tree[Tree[x].ch[]].mark ^= ; Tree[Tree[x].ch[]].mark ^= ; Tree[x].mark = ; swap(Tree[x].ch[] , Tree[x].ch[]); } } void pushdown_all(int x){ if(nroot(x)) pushdown_all(Tree[x].fa); pushdown(x); } inline void Splay(int x){ pushdown_all(x); while(nroot(x)){ if(nroot(Tree[x].fa)) ZigZag(son(x) == son(Tree[x].fa) ? Tree[x].fa : x); ZigZag(x); } } inline void access(int x){ ; x ; y = x , x = Tree[x].fa){ Splay(x); Tree[x].ch[] = y; pushup(x); } } inline int findroot(int x){ access(x); Splay(x); pushdown(x); ]) pushdown(x = Tree[x].ch[]); Splay(x); return x; } inline void makeroot(int x){ access(x); Splay(x); Tree[x].mark ^= ; } inline void split(int x , int y){ makeroot(x); access(y); Splay(y); } inline void link(int x , int y){ makeroot(x); Tree[x].fa = y; } inline void cut(int x , int y){ split(x , y); Tree[y].ch[] = Tree[x].fa = ; pushup(y); } inline void change(int x , int type , ld a , ld b){ access(x); Splay(x); Tree[x].type = type; Tree[x].a = a; Tree[x].b = b; getpre(x); pushup(x); } int main(){ freopen("4546.in" , "r" , stdin); freopen("4546.out" , "w" , stdout); N = read(); int M = read(); read(); ; i <= N ; ++i){ Tree[i].type = read(); scanf("%Lf %Lf" , &Tree[i].a , &Tree[i].b); getpre(i); } while(M--){ ld a , b , times , jc; int d , e; if(scanf("%s" , s) == EOF) ; ]){ case 'a': d = read() + ; e = read() + ; link(d , e); break; case 'd': d = read() + ; e = read() + ; cut(d , e); break; case 'm': d = read() + ; e = read(); scanf("%Lf %Lf" , &a , &b); change(d , e , a , b); break; case 't': d = read() + ; e = read() + ; scanf("%Lf" , &a); if(findroot(d) != findroot(e)) puts("unreachable"); else{ split(d , e); b = ; times = jc = ; a -= 0.5; ; i <= ; ++i){ b += times * Tree[e].point[i] / jc; times *= a; jc *= (i + ); } printf("%.9Lf\n" , b); } } } ; }
Luogu4546 THUWC2017 在美妙的数学王国中畅游 LCT、泰勒展开的更多相关文章
- [THUWC2017]在美妙的数学王国中畅游 LCT+泰勒展开+求导
p.s. 复合函数求导时千万不能先带值,再求导. 一定要先将符合函数按照求导的规则展开,再带值. 设 $f(x)=g(h(x))$,则对 $f(x)$ 求导: $f'(x)=h'(x)g'(h(x)) ...
- [BZOJ5020][THUWC2017]在美妙的数学王国中畅游(LCT)
5020: [THUWC 2017]在美妙的数学王国中畅游 Time Limit: 80 Sec Memory Limit: 512 MBSec Special JudgeSubmit: 323 ...
- 【BZOJ5020】[LOJ2289]【THUWC2017】在美妙的数学王国中畅游 - LCT+泰勒展开
咕咕咕?咕咕咕! 题意: Description 数字和数学规律主宰着这个世界. 机器的运转, 生命的消长, 宇宙的进程, 这些神秘而又美妙的过程无不可以用数学的语言展现出来. 这印证了一句古老的名言 ...
- BZOJ5020: [THUWC 2017]在美妙的数学王国中畅游(LCT,泰勒展开,二项式定理)
Description 数字和数学规律主宰着这个世界. 机器的运转, 生命的消长, 宇宙的进程, 这些神秘而又美妙的过程无不可以用数学的语言展现出来. 这印证了一句古老的名言: ...
- 【BZOJ5020】【THUWC2017】在美妙的数学王国中畅游 LCT 泰勒展开
题目大意 给你一棵树,每个点有一个函数\(f(x)\) 正弦函数 \(\sin(ax+b) (a\in[0,1],b\in[0,\pi],a+b\in[0,\pi])\) 指数函数 \(e^{ax+b ...
- 洛谷P4546 [THUWC2017]在美妙的数学王国中畅游 [LCT,泰勒展开]
传送门 毒瘤出题人卡精度-- 思路 看到森林里加边删边,容易想到LCT. 然而LCT上似乎很难实现往一条链里代一个数进去求和,怎么办呢? 善良的出题人在下方给了提示:把奇怪的函数泰勒展开搞成多项式,就 ...
- [THUWC2017][bzoj5020] 在美妙的数学王国中畅游 [LCT+泰勒展开]
题面 LOJ传送门 思路 这里很重要 它提示我们,把给定的三个函数泰勒展开,并用LCT维护每一项泰勒展开式的值,维护十几项就满足了题目的精度要求 我们考虑一个函数在0位置的泰勒展开 $f(x)=\su ...
- 「LOJ 2289」「THUWC 2017」在美妙的数学王国中畅游——LCT&泰勒展开
题目大意: 传送门 给一个动态树,每个节点上维护一个函数为$f(x)=sin(ax+b)$.$f(x)=e^{ax+b}$.$f(x)=ax+b$中的一个. 支持删边连边,修改节点上函数的操作. 每次 ...
- bzoj 5020(洛谷4546) [THUWC 2017]在美妙的数学王国中畅游——LCT+泰勒展开
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=5020 https://www.luogu.org/problemnew/show/P4546 ...
随机推荐
- 第一个React Native程序踩到的那些坑
毫不夸张的说用React Native写一个Hello World !程序是我碰到最复杂的Hello World.网络上的有关的环境搭建相关的文档也很多,但是总是有这样那样的问题. 官方中文版的安装文 ...
- 记录修改安卓5.0系统浏览器UI遇到的部分问题
碎碎念 今年七月份本科毕业后入职一家会议平板公司,经过一个一个多月的咸鱼培训轮岗生活,接手了几个小任务,本次记录一下其中一个任务:修改安卓5.0系统浏览器UI.刚接到任务的时候,本以为是很简单的一个任 ...
- Centos7下搭建SVN服务,本地提交代码自动同步到WEB目录
1.安装SVN服务[root@bogon ~]# yum -y install subversion 2.查看svnserve安装目录[root@bogon ~]# whereis svnserves ...
- enum类使用
状态常量类使用enum public class TestEnums{ public enum STATUS{ NOMAL("01","正常"), DELETE ...
- persist与checkpoint
1.当反复使用某些RDD时建议使用persist(缓存级别)(采用默认缓存级别时为cache())来对数据进行缓存. 2.如果某个步骤的RDD计算特别耗时或经历很多步骤的计算,当重新计算时代价特别大, ...
- python包中__init__.py的作用
1.__init__.py定义包的属性和方法 一般为空文件,但是必须存在,没有__init__.py表明他所在的目录只是目录不是包 2.导入包的时候使用 例如有一个test目录,test下有xx1.p ...
- sftp 建立用户
1.创建sftp组:#groupadd sftp 2.创建测试账户:#useradd -g sftp -s /bin/false testuser 修改密码:# passwd sftp 3.修改测试账 ...
- 戴尔dell服务器硬件故障SMTP邮件报警idrac配置
上次公司有台戴尔的服务器硬盘故障了却没有及时发现,后面就研究了一下看到戴尔的idrac有硬件SMTP报警功能 然后自己折腾了一下,一开始配置不成功,后面问了一下戴尔官方的最好自己再摸索了一下解决了,做 ...
- 17秋 软件工程 团队第五次作业 Alpha Scrum12
各个成员今日完成的任务 Alpha版本完成. 项目的发布说明 本版本的新功能 1.部门人员管理,包括纳新申请与审核: 2.部门活动发布与查看: 3.部门活动相册: 4.子部门信息录入. 软件对运行环境 ...
- Looper loop
public static void loop() { final Looper me = myLooper(); if (me == null) { throw new RuntimeExcepti ...