博客
关于我
程序设计入门4 子序列的和
阅读量:390 次
发布时间:2019-03-05

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

子序列的和(subsequence)

输入两个正整数n<m<10^6,输出1/n^2 + 1/(n+1)^2 + …… + 1/m^2,保留5位小数。输入包含多组数据,结束标记为n=m=0。提示:本题有陷阱。
样例输入:
2 4
65536 655360
0 0
样例输出:
Case 1: 0.42361

Case 2: 0.00001

一,注意事项(关于大整数相乘溢出问题):

 

#include
int main(){ int n; long long int n_2; scanf("%d",&n); n_2 = n * n; printf("%lld", n_2); return 0;}

这里假设n = 111111,则111111*111111为11位的,,,虽然小于long long的64位,,,但是n*n由于两个乘数为int,最后的结果依然会用int(10位)表示,纵然式子的左边是long long,依然会溢出。。。

 

虽然网上说强制转换可以解决问题,即n_2 = (long long)n * n;但我的电脑上的编译器会显示栈溢出。最保险的方法就是把乘数也设成long long.

转载地址:http://rxlwz.baihongyu.com/

你可能感兴趣的文章
MySQL与Oracle的数据迁移注意事项,另附转换工具链接
查看>>
mysql丢失更新问题
查看>>
MySQL两千万数据优化&迁移
查看>>
MySql中 delimiter 详解
查看>>
MYSQL中 find_in_set() 函数用法详解
查看>>
MySQL中auto_increment有什么作用?(IT枫斗者)
查看>>
MySQL中B+Tree索引原理
查看>>
mysql中cast() 和convert()的用法讲解
查看>>
mysql中datetime与timestamp类型有什么区别
查看>>
MySQL中DQL语言的执行顺序
查看>>
mysql中floor函数的作用是什么?
查看>>
MySQL中group by 与 order by 一起使用排序问题
查看>>
mysql中having的用法
查看>>
MySQL中interactive_timeout和wait_timeout的区别
查看>>
mysql中int、bigint、smallint 和 tinyint的区别、char和varchar的区别详细介绍
查看>>
mysql中json_extract的使用方法
查看>>
mysql中json_extract的使用方法
查看>>
mysql中kill掉所有锁表的进程
查看>>
mysql中like % %模糊查询
查看>>
MySql中mvcc学习记录
查看>>