博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
LightOJ1234 Harmonic Number 调和级数求和
阅读量:6572 次
发布时间:2019-06-24

本文共 1374 字,大约阅读时间需要 4 分钟。

【题目】

 

【预备知识】

,其中r是欧拉常数,const double r= 0.57721566490153286060651209;

这个等式在n很大 的时候 比较精确。

 

【解法】可以在 n较小的时候,比如n<1e6时,直接用预处理的打表O(1)求值,在n比较 大的时候,运用以上公式,此时要减去 1/(2*n)加以修正。

#include
#include
using namespace std;const double euler= 0.57721566490153286060651209;const int maxn = 1e6;double a[maxn];int cas = 1;int main(){ long long n; a[1] = 1; for(int i=2; i
>t; while(t--){ cin>>n; if(n < maxn){ printf("Case %d: %.10lf\n",cas++,a[n]); continue; } double ans = log(1+n) + euler - 1.0/(2*n); printf("Case %d: %.10lf\n",cas++,ans); } return 0;}

 

 

【分块打表】

虽然1e8的表打不出来,但1e6的表很好打,所以每隔100个数记录一次前缀和。到时用的时候,O(1)取出最接近n的前缀和,余下不足100个数暴力 求和即可。

 

#include
#include
using namespace std;const double euler= 0.57721566490153286060651209;const int maxn = 1e8+100;double a[maxn/100];int count = 1;int cas = 1;int main(){ long long n; a[0] = 0; double s = 0; for(int i=1; i
>t; while(t--){ double ans = 0; cin>>n; int num = n / 100;//对应a[num] ans += a[num]; for(long long i=num * 100 + 1; i<=n; i++){ ans += 1.0/i; } printf("Case %d: %.10lf\n", cas++, ans); } return 0;}

 

转载于:https://www.cnblogs.com/czsharecode/p/9786135.html

你可能感兴趣的文章
Nginx学习之如何搭建文件防盗链服务
查看>>
【全面解析DeepZoom 之三】建立DeepZoom应用
查看>>
利用shell脚本自动获取awr报表
查看>>
activeMq安装
查看>>
通过反射获得 spring 的 RequestMapping value值
查看>>
ubuntu python PIL
查看>>
【转】探索式测试:基本概念
查看>>
【转】浅谈反应测试
查看>>
【转】 Monkey测试1——Monkey的使用
查看>>
什么是.Net的异步机制(APM核心:IAsyncResult) - step 3
查看>>
(转)ElasticSearch学习
查看>>
自动化测试工具Selenium和QTP的比较
查看>>
Mysql order by 排序 varchar 类型数据
查看>>
像使用linux一样使用mac
查看>>
【转载】linux 压缩和解压缩命令gz、tar、zip、bz2
查看>>
轻量级AOP的另一种实现(100%开源)
查看>>
django迁移数据库报错解决
查看>>
51nod——1640 天气晴朗的魔法 有边权限制的最大生成树
查看>>
OpenFlow技术白皮书-V1.0
查看>>
Ubuntu 安装Eclipse CDT 开发C、C++
查看>>