UVa 10883 (组合数 对数) Supermean
在纸上演算一下就能看出答案是:sum{ C(n-1, i) * a[i] / 2^(n-1) | 0 ≤ i ≤ n-1 }
组合数可以通过递推计算:C(n, k) = C(n, k-1) * (n-k-1) / k
但是n太大了,直接计算组合数会爆double的。所以计算的时候要取一下对数就行了,组合数对数的递推相应就变成了log_C(n, k) = log_C(n, k-1) + log(n-k-1) - log(k)
#include <cstdio>
#include <cmath> const int maxn = + ;
const double ln2 = log(2.0);
double a[maxn], log_c[maxn]; int main()
{
//freopen("in.txt", "r", stdin); int n, T;
scanf("%d", &T);
log_c[] = ;
for(int kase = ; kase <= T; kase++)
{
scanf("%d", &n);
for(int i = ; i < n; i++) scanf("%lf", &a[i]);
n--;
double ans = ;
for(int i = ; i <= n; i++) log_c[i] = log_c[i-] + log(n-i+) - log(i); for(int i = ; i <= n; i++)
{
if(a[i] > ) ans += exp(log_c[i] + log(a[i]) - n * ln2);
else if(a[i] < ) ans -= exp(log_c[i] + log(-a[i]) - n * ln2);
} printf("Case #%d: %.3f\n", kase, ans);
} return ;
}
代码君
UVa 10883 (组合数 对数) Supermean的更多相关文章
- UVA - 10883 Supermean
		
Description Problem F Supermean Time Limit: 2 second "I have not failed. I've just found 10,000 ...
 - UVa 10883 超级平均数(二项式系数+对数计算)
		
https://vjudge.net/problem/UVA-10883 题意: 给出n个数,每相邻两个数求平均数,依次类推,最后得到1个数,求该数. 思路: 演算一下可以发现最后各个数的系数就是二项 ...
 - 紫书 习题 10-21 UVa 1649 (组合数)
		
C(n, k) = m, 固定k,枚举k 这里用到了组合数的一个性质 当k固定的时候,C(2 * k, k) 最小 C(m, k)最大(对于这道题而言是这样,因为大于m 就最终答案不可能为m了) 所以 ...
 - UVa 10253 (组合数 递推) Series-Parallel Networks
		
<训练之南>上的例题难度真心不小,勉强能看懂解析,其思路实在是意想不到. 题目虽然说得千奇百怪,但最终还是要转化成我们熟悉的东西. 经过书上的神分析,最终将所求变为: 共n个叶子,每个非叶 ...
 - uva - 10833 Supermean(二项式系数,对指数)
		
模拟发现,每个元素求和时,元素的系数是二项式系数,于是ans=sum(C(n-1,i)*a[i]/2^(n-1)),但是n太大,直接求会溢出,其实double的范围还是挺大的,所以可以将组合数转化成对 ...
 - 紫书 例题 10-17 UVa 1639(数学期望+对数保存精度)
		
设置最后打开的是盒子1, 另外一个盒子剩下i个 那么在这之前打开了n + n - i次盒子 那么这个时候的概率是C(2 * n - i, n) p ^ (n+1) (1-p)^ (n - i) 那么反 ...
 - uva 1639--精度处理方法之取对数(uva 1639)
		
1639 - Candy Time limit: 3.000 seconds 1639 CandyLazyChild is a lazy child who likes candy very much ...
 - 【每日一题】 UVA - 11809 Floating-Point Numbers 阅读题+取对数处理爆double
		
https://cn.vjudge.net/problem/UVA-11809 题意:很长orz 题解:算一下输入范围,发现用double是读不进来的,在这里wa了半天,(double 1e300 ...
 - How do you add? UVA - 10943(组合数的隔板法!!)
		
题意: 把K个不超过N的非负整数加起来,使它们的和为N,有多少种方法? 隔板法...不会的可以买一本高中数学知识清单...给高中班主任打个广告.... 隔板法分两种...一种是不存在空集 = C(n- ...
 
随机推荐
- WPF解析TTF 字体
			
偶遇需要自己解析 TTF 字体并显示,此做... using System; using System.Collections.Generic; using System.Drawing.Text; ...
 - 只是一个用EF写的一个简单的分页方法而已
			
只是一个用EF写的一个简单的分页方法而已 慢慢的写吧.比如,第一步,先把所有数据查询出来吧. //第一步. public IQueryable<UserInfo> LoadPagesFor ...
 - Django 学习笔记之一 环境搭建
			
以后的文章都是在windows系统进行的 首先下载安装Django包 方式1:使用 pip或easy_insatll来进行安装 同时按住win+R键,弹出命令行运行框输入,pip install Dj ...
 - CSDN——【低调的草原狼】——Ext4.2学习目录整理
			
最近在研究ExtJS,发现CSDN中有个博客中一系列文档非常优秀,但是没有对目录进行整理,在此稍作整理,也为以后自己研究打下一个基础: 原文作者:低调的草原狼 目录: 1.ExtJS4.2学习 ...
 - CSS3技巧:利用css3径向渐变做一张优惠券(转)
			
在很多购物网站上都能看到优惠券,代金券,什么什么的券,但基本都是图片直接放上去,那么你有没有想过css来做一个呢,反正我是这样想过.那么你怎么做呢,切图做背景平铺边缘,嗯,有这样想过,如今css3技术 ...
 - 【BZOJ】【2157】旅游
			
LCT 直到动手写拆边为点的时候才发现根本不会写……去orz了一下Hzwer(话说这题应该也用不着LCT吧……下次再换种姿势写一遍好了) /****************************** ...
 - 剑指offer--面试题6
			
题目:由前序.中序遍历序列重建二叉树 虽然思路能想到,但是实际写却无从下手...下面重现作者代码,多多实践... #include<exception> //首先定义二叉树节点 struc ...
 - 解谜谷歌 DevOps:什么特质可以打造世界级可靠系统?
			
[编者按]本文是 Gene Kim 总结自对 Randy Shoup 两个小时的采访,主要关注谷歌 DevOps 的提升之道.本文系 OneAPM联合高效运维编译整理. Randy Shoup 曾协助 ...
 - java基础知识回顾之java Thread类学习(七)--java多线程安全问题(死锁)
			
死锁:是两个或者两个以上的线程被无限的阻塞,线程之间互相等待所需资源. 线程死锁产生的条件: 当两个线程相互调用Join()方法. 当两个线程使用嵌套的同步代码块的时候,一个线程占用了另一个线程的锁, ...
 - java基础知识回顾之javaIO类--File类应用:删除带内容的目录
			
/** * 深度删除一个带内容的目录 * 原理:必须从里往外删除,需要深度遍历 * @author Administrator * */ public class FileDeleteList { / ...