首页 > 代码库 > UVA 10883 Supermean 上下取对数防溢出
UVA 10883 Supermean 上下取对数防溢出
题目链接:点击打开链接
溢出了半天,觉累不爱
#include<math.h> #include<iostream> #include<stdio.h> using namespace std; #define ll int int main(){ ll Cas= 1, T; cin>>T; while(T--){ ll n; cin>>n; double sum = 0, a; double hehe = 0; for(ll i = 0; i < n;i++){ cin>>a; if(a<0) sum-=exp(hehe+log(-a)-(n-1)*log(2)); else sum += exp(hehe+log(a)-(n-1)*log(2)); hehe+=log(n-1-i)-log(i+1); } printf("Case #%d: %.3lf\n",Cas++,sum); } return 0; }
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。