关于C语言求一串阶乘的和,求高手帮我看一下!
求:1!+2!+3!+...+20!。 #include<stdio.h> void main() { long i=1,sum=0; int m; for(m=1;m<=20;m++) { i=i*m; sum=sum+i; } Printf("sum=%ld\n",sum); } 这个程序应该挺简单的,这是我写的,但结果是错的。而正确的写法是第四行全部定义为long型,第十行输出格式为%e。 我觉得我写的应该不错。程序中明明是长整型,为什么要用float定义,最后用%e与否怎么会影响了结果的正确?
如果对于小数字来说,这个代码没有问题。但在这个题中有问题。 因为20以内的阶乘相加的结果远远超过长整形的位数。这个代码运算结果为268040729,但用科学计数法表示是2.56133e+18,确切的结果是2561327494111820313。也就是说,当长度超过时结果就会不正确。 用浮点型是为了用科学计数法表示,科学计数法前面的那个2.56133是浮点型。而m可以不用float定义。 如果想要得出精确的答案,可以把数放到数组中,在数组中运算结果。 还有,你的题目里面有些地方打错了。“Printf”前面的“P”不能大写。倒数第三行应该写“float”而不是“long”。 如果还有什么不明白的地方可以问我。
LZ贴出来的代码没什么问题呀,是对的! 如果第4行是long型,用%e输出是不对的。%e是浮点数科学记数法输出的格式。而且,既然是阶乘数累加,当然用长整型啦。
答:WORD本身就有稿纸,如果你把OFFICE完全安装后,利用新建文件向导里面的稿纸向导就可以打稿纸了,注意OFFICE必须是完全安装,如果是默认安装的话,就没有。详情>>
问:挺简单的一C函数,不过我是初学者,暂时还不会写,请好心人多多帮忙!
答:int mystrlen(char *str) { int n = 0; while (*str) { n++; str++;} return n; } voi...详情>>