标题:有谁可以帮我解决一下??
只看楼主
三岩
Rank: 1
等 级:新手上路
帖 子:20
专家分:6
注 册:2010-7-19
结帖率:100%
已结贴  问题点数:20 回复次数:4 
有谁可以帮我解决一下??
#include <stdio.h>
void main()
{float sum=0,p,i,j;
for(i=1;i<=20;i++)
{for(j=1,p=1;j<=i;j++)
p=p*j;
sum=sum+p;}
printf("1!+2!+3!+4!+……+20!=%e\n",sum);}
这个程序是正确的!但是当我把数值类型float改为long int ,%e改为%ld时,虽然结果肯定错误,但系统却冷静地给了我一个答案,而且如果你事先不算一下结果,还以为答案正确呢!!为什么结果大大超出容许范围,系统却如此处置???我用的是VC++6.0
搜索更多相关主题的帖子: void include 
2010-07-30 22:32
pangding
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:北京
等 级:贵宾
威 望:94
帖 子:6784
专家分:16751
注 册:2008-12-20
得分:5 
这跟你用的编译器没关系。
2010-07-31 02:59
honesty2008
Rank: 2
等 级:论坛游民
帖 子:8
专家分:25
注 册:2010-7-29
得分:5 
确实,用长整型结果是268040729,(错误)
用__int64结果是2561327494111820313(正确)

敢于面对现实,勇于战胜自己。
2010-07-31 09:11
sunyh1999
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:版主
威 望:14
帖 子:1178
专家分:3032
注 册:2009-5-17
得分:5 
长整型范围为从-9223372036854775808~9223372036854775807
DOUBLE 64 1.7E–308~1.7E+308
float 32 3.4E–038~3.4E+038


欢迎来到我的博客:http://blog..cn/noisunyuhong
2010-07-31 09:38
BJ_BOY
Rank: 4
等 级:业余侠客
威 望:1
帖 子:77
专家分:225
注 册:2010-2-4
得分:5 
在编译器安装目录的include目录下,找到limits.h,你可以看到long int型的数值范围(不同编译器不同):
#define LONG_MAX    2147483647L
#define LONG_MIN    (-LONG_MAX-1)

  显然:256132749411182031不在该范围内。那么为什么答案会出256132749411182031这样的结果呢?我们需要了解以下几方面的知识:
  1)两种存储方式little-endian和big-endian,有兴趣的人可上网随便查查就知道了。
  2)内存截断带来的问题。
  了解了上面两方面知识,就不难分析出为什么会出这样的结果了。

2010-07-31 10:53



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-314442-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.153568 second(s), 7 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved