「AGC020F」 Arcs on a Circle

Link

这个题非常 Amazing 啊。果然AtCoder全是智商题

首先你可以注意到数据范围真的是小得离谱,让你想要爆搜。

然后你发现不可做,那考虑状压。

首先你发现这是一个环很烦,所以我们随便找一个端点断环为链。

问题转换为求能覆盖整个圆的不同的覆盖方式。

但是显然这样的方案有无数种,我们需要考虑优化。

注意到两段圆弧是否相交,仅与它们的起始位置的整数部分的值和小数部分有关。更进一步地,他们小数部分的相对大小决定了其是否相交。

若有 \(p_i\le p_j\),则两圆弧相交 \(\iff p_i+l_i\ge p_j\)。

拆分为整数和小数部分,有 \([p_i]+\{p_i\}+l_i\ge [p_j]+\{p_j\}\)。

若 \([p_i]+l_i\neq [p_j]\),则小数部分无影响。

若 \([p_i]+l_i= [p_j]\),则 \([p_i]+\{p_i\}+l_i\ge [p_j]+\{p_j\}\iff \{p_i\}\ge \{p_j\}\)。

不妨设相对位置互不相同。

于是我们可以考虑枚举所有圆弧小数部分的相对位置,然后状压DP即可。

/*---Author:HenryHuang---*/
/*---Never Settle---*/
#include<bits/stdc++.h>
using namespace std;
int s;
int a[10],tot;
long long ans;
int n,c;
int f[50][500];
int solve(){
memset(f,0,sizeof f); f[0][a[n]*(n+1)]=1;
for(int i=1;i<(n+1)*c;++i){
if(i%(n+1)){
int t=i%(n+1)-1,len=min(i+(n+1)*a[t],(n+1)*c);
for(int j=0;j<=s;++j){
if((j&(1<<t))==0){
for(int k=i;k<=(n+1)*c;++k)
f[j|(1<<t)][max(k,len)]+=f[j][k];
}
}
}
}
return f[s][(n+1)*c];
}
int main(){
ios::sync_with_stdio(0);
cin.tie(0),cout.tie(0);
cin>>n>>c;
s=(1<<(n-1))-1;--n;
for(int i=0;i<=n;++i) cin>>a[i];
sort(a,a+n+1);
do{
ans+=solve();
++tot;
}while(next_permutation(a,a+n));
cout<<setprecision(14)<<fixed<<(long double)ans/tot/pow(c,n)<<'\n';
return 0;
}

最新文章

  1. 调用webapi 错误:使用 HTTP 谓词 POST 向虚拟目录发送了一个请求,而默认文档是不支持 GET 或 HEAD 以外的 HTTP 谓词的静态文件。的解决方案
  2. 一段freemarker高级分页效果的代码
  3. ASP.NET Core--条件处理程序中的依赖注入
  4. ArcEngine奇怪异常:HRESULT:0x80040351
  5. 跟我学Windows Azure 一 创建Windows Azure试用账号
  6. UIColor与PatternImage
  7. android LocalActivityManager说明
  8. HDU 5266 pog loves szh III
  9. js 多媒体audio video
  10. Windows10 上运行Ubuntu Bash
  11. Can&#39;t call commit when autocommit=true(转)
  12. (转)最大似然估计&amp;贝叶斯估计
  13. 如何使用Ninja快速编译LLVM和Clang
  14. SVG---DEMO
  15. [经验交流] 影响 kubernetes 稳定性的因素
  16. AI-restful接口写法
  17. PAT A1014 Waiting in Line (30 分)——队列
  18. Docker(一)-Docker介绍
  19. .NET面试题系列(六)多线程
  20. Javascript调试利器console的使用

热门文章

  1. [ Java面试题 ]Java 开发岗面试知识点解析
  2. C语言编译器开发之旅(一):词法分析扫描器
  3. 如何不做登录请求而获取cookie到Jmeter里
  4. 状压dp(总结)状态压缩
  5. TVM中的调度原语
  6. 蓝牙mesh网络技术的亮点
  7. Windows下Qt VS 打包程序 到他人电脑安装运行出现的问题
  8. Spring Cloud02:Eureka Server注册中心
  9. 即时性能分析工具 Pyroscope
  10. [翻译]Go与C#的比较,第二篇:垃圾回收