题目

三维空间上有一个点,进行了\(n\)次移动

第\(i\)次为在\([0,L_i]\)内随机一个长度\(l_i\),向\(\vec P_i\)方向移动\(l_i\)

$\vec P_i $ 表示为 \((\alpha_i,\beta_i)\) ,意义为设 \(\vec P_i\) 在 \(xy\) 上的投影为 \(\vec Q_i\) , \(\alpha_i\) 为 \(\vec Q_i\) 和 \(xy\) 的夹角,\(\beta_i\) 为 \(\vec P_i\) 和 $ \vec Q_i$ 的夹角

从原点开始有一个球,每秒半径增加1个单位,在时刻\(i\)会消耗当前体积的能量

求消耗能量的期望值

$ n \le 3000 $

题解

  • 考虑最后的半径\(R\),答案即 $ E (\int_0^R \frac{4}{3} \pi x^3 dx) = \frac{\pi}{3} E(R^4)$

  • 设第\(i\)次移动的向量为\((a_i,b_i,c_i)x_i\) , \(x_i\) 为一个在 \([0,1]\)随机分布的变量

  • $E(R^4) =E ( ( (\sum a_ix_i)^2 + (\sum b_ix_i)^2 + (\sum c_ix_i)^2) ^2 ) $

  • 设 $ A_i = \sum a_ix_i $ ,BC同理,设 $ dp_{i,j,k,l} = E(A_ijB_ikC_i^l) $

  • 只需要求出\(dp\)即可求出 \(ans\)  

    根据二项式定理

    \[\begin{align}
    &dp_{i,j,k,l} = \sum_p\sum_q\sum_r dp_{i-1,j-p,k-q,l-r} \times (^j_p)(^k_q)(^l_r) \times a_i^pb_i^qc_i^rE(x_i^{p+q+r})\\
    &由于f(x)在[L,R]内的期望E(f(x)) = \frac{\int_L^R f(x) dx}{R-L} \\
    &所以E(x_i^{p+q+r}) \ = \ \frac{1}{p+q+r+1} \\
    \end{align}
    \]

  • 时间复杂度:\(O(5^6n)\)

  • 由于有大量无用状态,采用记忆化搜索

Code

#include<bits/stdc++.h>
#define ld long double
using namespace std;
const int N=3010;
int T,n,Tim,C[5][5],g[N][5][5][5];
ld a[N][5],b[N][5],c[N][5],f[N][5][5][5],ny[13];
ld cal(int i,int j,int k,int l){
if(!i)return !j&&!k&&!l;
if(g[i][j][k][l]==Tim)return f[i][j][k][l];
g[i][j][k][l]=Tim;
ld &res=f[i][j][k][l];
res=0;
for(int p=0;p<=j;++p)
for(int q=0;q<=k;++q)
for(int r=0;r<=l;++r)
res+=cal(i-1,j-p,k-q,l-r)*C[j][p]*C[k][q]*C[l][r]*a[i][p]*b[i][q]*c[i][r]*ny[p+q+r+1];
return res;
}
int main(){
freopen("undertale.in","r",stdin);
freopen("undertale.out","w",stdout);
scanf("%d",&T);
for(int i=0;i<5;++i)C[i][0]=1;
for(int i=1;i<5;++i)
for(int j=1;j<5;++j)
C[i][j]=C[i-1][j]+C[i-1][j-1];
for(int i=1;i<13;++i)ny[i]=1.0/i;
while(T--){
scanf("%d",&n);
for(int i=1;i<=n;++i){
ld x,y,l;
scanf("%Lf%Lf%Lf",&x,&y,&l);
a[i][0]=b[i][0]=c[i][0]=1;
c[i][1]=sin(y)*l;l*=cos(y);
b[i][1]=sin(x)*l;
a[i][1]=cos(x)*l;
for(int j=2;j<5;++j){
a[i][j]=a[i][j-1]*a[i][1];
b[i][j]=b[i][j-1]*b[i][1];
c[i][j]=c[i][j-1]*c[i][1];
}
}
++Tim;
ld ans = cal(n,4,0,0) + cal(n,0,4,0) + cal(n,0,0,4)
+2*cal(n,2,2,0) + 2*cal(n,2,0,2) + 2*cal(n,0,2,2);
ans*=acos(-1)/3;
printf("%.10Lf\n",ans);
}
return 0;
}

【JZOJ100208】【20190705】传说之下的更多相关文章

  1. 【资源分享】Undertale(传说之下)简体中文精品整合包

    *----------------------------------------------[下载区]----------------------------------------------* ...

  2. [游记] pkusc 2021 游记

    流水账 Day-4 写了ICPC的一道DP,有点细节,虽然写得有点难受,但挺好玩 Day-3 写了PKUSC2018最水的一题 是随机开的题 Day-2 可以去pkusc了,从今天中午开始停课 刚吃完 ...

  3. [原创]webapp/css3实战,制作一个《炉石传说》宣传页

    在移动网页,尤其是webapp中常需要用到大量的css3动画,来获得良好交互体验 我之前帮朋友做了一个,可惜没帮上忙现在和大家分享一下 目标是要做一个<炉石传说>游戏的介绍宣传页面,文字内 ...

  4. 转:界面之下:还原真实的 MVC、MVP、MVVM 模式

    前言 做客户端开发.前端开发对MVC.MVP.MVVM这些名词不了解也应该大致听过,都是为了解决图形界面应用程序复杂性管理问题而产生的应用架构模式.网上很多文章关于这方面的讨论比较杂乱,各种MV*模式 ...

  5. 风口之下,猪都能飞。当今中国股市牛市,真可谓“错过等七年”。 给你一个回顾历史的机会,已知一支股票连续n天的价格走势,以长度为n的整数数组表示,

    转自:http://www.cnblogs.com/ranranblog/p/5845010.html 风口之下,猪都能飞.当今中国股市牛市,真可谓“错过等七年”. 给你一个回顾历史的机会,已知一支股 ...

  6. 炉石传说 C# 开发笔记(6月底小结)

    炉石传说的开发,已经有30个工作日了. 关于法术的定义方法,有过一次重大的变更:法术效果是整个炉石的核心,正是因为丰富的法术效果,才造就了炉石的可玩性. 原来构思的时候,对于法术效果没有充分的理解,所 ...

  7. 炉石传说 C# 开发笔记 (源代码整理公开)

    源代码已经整理过了,去除了不需要的项目. 注意:以前文章中出现过的Git已经变更过了,请以前关注过,Fork过的朋友,重新Fork一下. GitHub地址 卡牌XML文件的做成:(Git上面是没有XM ...

  8. 炉石传说 C# 开发笔记 (续)

    炉石传说山寨的工作一直在进行着,在开发过程中深深体会到,对于业务的理解和整个程序的架构的整理远比开发难得多. 在开发过程中,如果你的模型不合理,不准确,很有可能造成代码的混乱,冗余,难以维护和扩展性比 ...

  9. 炉石传说 C# 开发笔记

    最近在大连的同事强力推荐我玩 炉石传说,一个卡牌游戏.加上五一放一个很长很长的假期,为了磨练自己,决定尝试开发一个C#的炉石传说. 这件事情有人已经干过了,开发了一个网页版的炉石,但是貌似不能玩... ...

随机推荐

  1. Java8 新特性 Stream 无状态中间操作

    无状态中间操作 Java8 新特性 Stream 练习实例 中间无状态操作,可以在单个对单个的数据进行处理.比如:filter(过滤)一个元素的时候,也可以判断,比如map(映射)... 过滤 fil ...

  2. 【计算机组成原理】中央处理器CPU

    一.CPU的功能和基本结构 1.功能 当用计算机解决某个问题是,我们首先必须为他编写程序,程序是一个指令序列,这个序列明确告诉计算机应该执行什么操作,在什么地方找到用来操作的数据,一旦把程序装入内存器 ...

  3. 《 .NET并发编程实战》阅读指南 - 第9章

    先发表生成URL以印在书里面.等书籍正式出版销售后会公开内容.

  4. [转] vue前端异常监控sentry实践

    1. 监控原理 1.1 onerror 传统的前端监控原理分为异常捕获和异常上报.一般使用onerror捕获前端错误: window.onerror = (msg, url, line, col, e ...

  5. 单片机成长之路(51基础篇) - 026 基于stm89c52之单片机看门狗

    基于stc89c52的看门狗,代码如下: main.c #include "stc89c5x_Quick_configuration.h" // 自定义头文件 #include & ...

  6. c#WinForm中TeeChart控件的注册和使用

    首先要注册好TeeChart控件,注册方法参考:https://blog.csdn.net/my_clear_mind/article/details/79741020 完成注册之后,新建一个WinF ...

  7. tomcat采坑

    1. tomcat采坑 1.1. 采坑 今天又踩了个以前踩过的坑,运维系统迁移到docker,使用的tomcat版本是tomcat8,而原来的版本是tomcat7.0.53,导致的结果就是系统间请求一 ...

  8. iOS开发工具:Alcatraz、SVGKit、Lin以及Transformifier等

    转自:http://www.cocoachina.com/applenews/devnews/2013/0606/6352.html Alcatraz:Xcode包管理器 Alcatraz是一个开源的 ...

  9. .NET Core中 实现H5微信登录(静默授权方式)

    需求 假设现在有一个H5需要有微信登录.手机号登录.邮箱登录 三种登录方式.让我们一起来看看微信登录如何实现吧 界面: 最终实现的效果图(登录成功后返回个人页): 因为微信登录目前没有实现移动端的其他 ...

  10. 【转载】Gradle学习 第九章:Groovy快速入门

    转载地址:http://ask.android-studio.org/?/article/17 To build a Groovy project, you use the Groovy plugin ...