Fortran Coder

查看: 9332|回复: 2
打印 上一主题 下一主题

[求助] 算出的y2结果错了,请求帮忙!

[复制链接]

1

帖子

1

主题

0

精华

新人

F 币
15 元
贡献
4 点
跳转到指定楼层
楼主
发表于 2015-7-6 16:20:25 | 只看该作者 |只看大图 回帖奖励 |倒序浏览 |阅读模式
算出来的y1是正确的,但是算y2时算错了。找不到原因了。请大家帮我看看!

T1NWB4G_Z]$HUAWPES21F@E.png (4.22 KB, 下载次数: 196)

T1NWB4G_Z]$HUAWPES21F@E.png
分享到:  微信微信
收藏收藏 点赞点赞 点踩点踩

2015

帖子

12

主题

5

精华

论坛跑堂

臭石头雪球

F 币
1572 元
贡献
676 点

美女勋章热心勋章星光勋章新人勋章贡献勋章管理勋章帅哥勋章爱心勋章规矩勋章元老勋章水王勋章

沙发
发表于 2015-7-6 17:42:53 | 只看该作者
请给出 ess.dat 文件

954

帖子

0

主题

0

精华

大师

F 币
184 元
贡献
75 点

规矩勋章元老勋章新人勋章水王勋章热心勋章

QQ
板凳
发表于 2015-7-6 17:55:07 | 只看该作者
OCR 工具,嘿嘿

[Fortran] 纯文本查看 复制代码
Program qmzy11
  Implicit None
  Integer , parameter :: N = 500
  Integer :: i
  Real(Kind=8) :: x0(N), y0(N) , x1 , y1 , x2 , y2
  Open (11, File='ess.dat')
  Open (12, File='dt.dat')
  Do i = 1, 50
    Read (11, *) x0(i), y0(i)
  End Do
  x1 = 0.2655D0
  Call lagr(x0, y0, N, x1, y1)
  x2 = 0.3886D0
  Call lagr(x0, y0, N, x2, y2)
  Write (12, 1) x1, x2
  Write (*, 1) y1, y2
  1 Format (7X, 2E15.7)
End Program qmzy11

Subroutine lagr(x0, y0, n, x, y)
  Implicit None
  Integer :: i , j , n
  Real(Kind=8) :: x0(n), y0(n) , p , x , y
  y = 0.D0
  Do i = 1, n
    p = 1.0D0
    Do j = 1, n
      If (i==j) cycle
      p = p*(x-x0(j))/(x0(i)-x0(j))
    End Do
    y = y + p*y0(i)
  End Do
End Subroutine lagr
您需要登录后才可以回帖 登录 | 极速注册

本版积分规则

捐赠本站|Archiver|关于我们 About Us|小黑屋|Fcode ( 京ICP备18005632-2号 )

GMT+8, 2024-11-1 09:30

Powered by Tencent X3.4

© 2013-2024 Tencent

快速回复 返回顶部 返回列表