- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试计算序列的近似值,并将精度设置为 1E-6。
int i=1;
float x;
scanf("%f",&x);
double sx = x,temp;
do{
temp = (pow(x,((2*i)+1)))/((2*i+1)*(fact(i))); //fact() is a function counting factorial
if((i+2)%2==1) sx-=temp;
else sx+=temp;
printf("%lf %lf\n",temp,sx);
i++;
}while(temp>1E-6);
printf("%lf",sx);
当输入小于2时,我得到预期的输出。但是当输入达到3时,出现负数。是因为堆栈溢出吗?但事实(10)并没有那么大,不是吗?我怎样才能得到正确的结果?
最佳答案
你问的是不是10!太大了,但是如果您在值溢出时观察 i
,您会看到 i == 12
。 temp
then 的表达式为:
325/25 x 12!
子表达式 25 x 12!值为 11975040000,如果它是一个整数表达式,则需要 34 位,如果 fact()
是一个整数函数,则需要 34 位。如果是32位整数函数就会溢出。
如果将 fact()
更改为无符号 64 位类型,它会更进一步,但这仅适用于 19!并且除数子表达式在收敛之前在 i=18
(29 x 18!) 处溢出。
使用以下阶乘函数实现,它将收敛于 i = 3
:
double fact(int n)
{
if (n >= 1)
return n * fact(n - 1);
else
return 1;
}
结果为 0.886207。对于任意大的 x 值,您将需要任意精度或“bignum”数学库,而不是内置类型。
受到 Lee Crocker 评论的启发,我尝试了各种表达方式(在 GDB Online 进行了测试)
1) 基于我的双重事实( int )
并减去你的无关括号;
double e = (2*i)+1 ;
temp = pow(x,e) / (e * fact(i));
x = 1 到 9 的结果:
x: 1.0 s(x): 0.746824
x: 2.0 s(x): 0.882081
x: 3.0 s(x): 0.886207
x: 4.0 s(x): 0.886227
x: 5.0 s(x): 0.886227
x: 6.0 s(x): 0.889677
x: 7.0 s(x): 2453.707036
x: 8.0 s(x): 1055556860.115990
x: 9.0 s(x): -nan
2) 使用tgamma()
:
temp = pow(x,e) / (e * tgamma(i+1)) ;
结果:
x: 1.0 s(x): 0.746824
x: 2.0 s(x): 0.882081
x: 3.0 s(x): 0.886207
x: 4.0 s(x): 0.886227
x: 5.0 s(x): 0.886226
x: 6.0 s(x): 0.882858
x: 7.0 s(x): -83.077451
x: 8.0 s(x): 3729162898.780624
3) 使用lgamma()
:
temp = pow(x,e) / exp(log(e) + lgamma(i+1)) ;
结果:
x: 1.0 s(x): 0.746824
x: 2.0 s(x): 0.882081
x: 3.0 s(x): 0.886207
x: 4.0 s(x): 0.886227
x: 5.0 s(x): 0.886236
x: 6.0 s(x): 1.904565
x: 7.0 s(x): -322346.422518
x: 8.0 s(x): 5416428382.734000
x: 9.0 s(x): -nan
对于x = 6.0
,结果有所不同,但所有版本都在此处崩溃。我不清楚哪个更好 - 我怀疑 fact()
。标准库函数没有提供任何重大改进。
4)添加Lee的表情进行测试(如果我正确理解了他的答案):
temp = exp(e * log(x) - log(e) - lgamma(i+1)) ;
结果:
x: 1.0 s(x): 0.746824
x: 2.0 s(x): 0.882081
x: 3.0 s(x): 0.886207
x: 4.0 s(x): 0.886227
x: 5.0 s(x): 0.886245
x: 6.0 s(x): 2.892730
x: 7.0 s(x): 96596.597282
x: 8.0 s(x): -720878097610.696167
x: 9.0 s(x): -18109761159507625984.000000
仅供引用,我的测试代码:
double s( double x )
{
double sx = x ;
double temp = 1.0 ;
for( int i = 1; temp > 1e-6; i++ )
{
double e = (2*i)+1 ;
// Uncomment one of the following:
//temp = pow(x,e) / (e * fact(i));
//temp = pow(x,e) / (e * tgamma(i+1)) ;
//temp = pow(x,e) / exp(log(e) + lgamma(i+1)) ;
//temp = exp(e * log(x) - log(e) - lgamma(i+1)) ;
sx += (i % 2) == 0 ? temp : -temp ;
}
return sx ;
}
int main()
{
for( double x = 1.0; x < 10.0; x += 1.0 )
{
printf( "x: %.1f s(x): %lf\n", x, s(x) ) ;
}
return 0;
}
关于c - 为什么C程序第10次循环结束时循环语句会出错?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58102796/
我正在编写一个类,我想知道哪一对方法更适合描述流程周期: start() -> stop() start() -> end() start() -> finish() 基本上这些方法将在执行任务之前和
对于 Android 小部件类名称是否应以“View”、“Layout”或两者都不结尾,是否存在模式或命名约定? 最佳答案 如果该类扩展了 View(或在其层次结构中扩展了 View),那么它应该以“
我正在尝试找到一个插件,该插件将使用 Verilog 突出显示匹配的开始/结束语句。 VIM 让它与花括号/括号一起工作,但它不能与它的开始/结束一起工作。我希望 VIM 突出显示正确的开始到正确的结
给出以下代码: % Generate some random data n = 10; A = cell(n, 1); for i=1:n A{i} = timeseries; A{i
我需要知道是否可以检测输入何时开始聚焦以及何时结束焦点 HTML 代码: JQuery 代码(仅示例我如何需要它): $('.datas').on('focusStart', alert("fo
所以我一直在思考一款游戏的想法,一款需要穿越时空的游戏。因此,我编写了一个 JFrame 来显示螺旋的 .gif,但它并没有在对话框显示时结束,而是保留在后台。我可以解决这个问题吗? import j
给出以下使用多线程的 Java 示例: import java.util.concurrent.*; public class SquareCalculator { private Ex
好吧,我有一个 do-while 循环,应该在使用点击“q”时结束,但它给了我错误消息,请帮忙。 package Assignments; import java.util.*; public cla
我如何有选择地匹配开始 ^或结束 $正则表达式中的一行? 例如: /(?\\1', $str); 我的字符串开头和结尾处的粗体边缘情况没有被匹配。我在使用其他变体时遇到的一些极端情况包括字符串内匹配、
我试图让程序在总数达到 10 时结束,但由于某种原因,我的 while 循环在达到 10 时继续计数。一旦回答了 10 个问题,我就有 int 百分比来查找百分比。 import java.util.
jQuery 中的 end() 函数将元素集恢复到上次破坏性更改之前的状态,因此我可以看到它应该如何使用,但我已经看到了一些代码示例,例如:on alistapart (可能来自旧版本的 jQuery
这个问题在这里已经有了答案: How to check if a string "StartsWith" another string? (18 个答案) 关闭 9 年前。 var file =
我正在尝试在 travis 上设置两个数据库,但它只是在 before_install 声明的中途停止: (END) No output has been received in the last 1
我创建了一个简单的存储过程,它循环遍历一个表的行并将它们插入到另一个表中。由于某种原因,END WHILE 循环抛出缺少分号错误。所有代码对我来说都是正确的,并且所有分隔符都设置正确。我只是不明白为什
您好,我正在使用 AVSpeechSynthesizer 和 AVSpeechUtterance 构建一个 iOS 7 应用程序,我想弄清楚合成何时完成。更具体地说,我想在合成结束时更改播放/暂停按钮
这是我的代码,我试图在响应后显示警报。但没有显示操作系统警报 string filepath = ConfigurationManager.AppSettings["USPPath"].ToStri
我想创建一个循环,在提供的时间段、第一天和最后一天返回每个月(考虑到月份在第 28-31 天结束):(“function_to_increase_month”尚未定义) for beg in pd.d
我目前正在用 Python 3.6 为一个骰子游戏编写代码,我知道我的编码在这方面有点不对劲,但是,我真的只是想知道如何开始我的 while 循环。游戏说明如下…… 人类玩家与计算机对战。 玩家 1
所以我已经了解了如何打开 fragment。这是我的困境。我的 view 旁边有一个元素列表(元素周期表元素)。当您选择一个元素时,它会显示它的信息。 我的问题是我需要能够从(我们称之为详细信息 fr
我想检测用户何时停止滚动页面/元素。这可能很棘手,因为最近对 OSX 滚动行为的增强创造了这种新的惯性效应。是否触发了事件? 我能想到的唯一其他解决方案是在页面/元素的滚动位置不再改变时使用间隔来拾取
我是一名优秀的程序员,十分优秀!