24小时热门版块排行榜    

查看: 838  |  回复: 4

清泠之渊

新虫 (初入文坛)

[求助] 来自女大学生的痛苦!用改进欧拉公式求数值解的程序!总是有两个错误!求大神指点! 已有1人参与

program text
real x(0),y(0),h,N
x(0)=0
y(0)=-1
h=0.1
N=2/H
do i=0,N
x(i+1)=x(i)+h
y(i+1)=y(i)+h*f(x(i),y(i))
yc=y(i)+h*f(x(i+1),y(i+1))
y(i+1)=(y(i+1)+yc)/2
print*,y(i+1)
enddo
end

发自小木虫IOS客户端
回复此楼
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

Yan_Jordan

木虫 (小有名气)

【答案】应助回帖

★ ★
感谢参与,应助指数 +1
jjdg: 金币+2, 感谢参与 2017-06-23 22:31:21
首先 程序不全,没有f函数, 建议贴出错误信息。

从以上代码看,楼主对x y两个数组的定义(没有维度信息)很有问题,需要提前初始化好数组,维度应该是N+1(如果N不定,可以用动态数组)

我尝试猜测了下楼主的意图代码如下
***********************************************
CODE:
PROGRAM test
        IMPLICIT NONE ! 强制所有变量都有初始化定义

        real :: h,yc
        INTEGER :: N, i
        real, dimension(:), ALLOCATABLE :: x, y !定义动态数组
        h=0.1
        N=floor(2/H)
       
        ALLOCATE(x(N+1), y(N+1)) !分配动态数组内存大小
        x(1)=0
        y(1)=-1  !迭代的初值
       
        do i=0,N
                x(i+1)=x(i)+h
                y(i+1)=y(i)+h*f(x(i),y(i))
                yc=y(i)+h*f(x(i+1),y(i+1))
                y(i+1)=(y(i+1)+yc)/2
                print*,y(i+1)
        enddo

        DEALLOCATE(x,y) !释放动态数组内存
        
   CONTAINS
        
        real FUNCTION f(x,y)
                IMPLICIT NONE
                real, INTENT(in) :: x, y
                f=sqrt(x**2+y**2)
        ENDFUNCTION

END PROGRAM test

*********************************************
2楼2017-06-23 16:57:50
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

Yan_Jordan

木虫 (小有名气)


jjdg: 金币+1, 感谢参与 2017-06-23 22:31:37
引用回帖:
2楼: Originally posted by Yan_Jordan at 2017-06-23 16:57:50
首先 程序不全,没有f函数, 建议贴出错误信息。

从以上代码看,楼主对x y两个数组的定义(没有维度信息)很有问题,需要提前初始化好数组,维度应该是N+1(如果N不定,可以用动态数组)

我尝试猜测了下楼主的 ...

CODE:
PROGRAM test IMPLICIT NONE ! 强制所有变量都有初始化定义 real :: h,yc INTEGER :: N, i real, dimension(:), ALLOCATABLE :: x, y !定义动态数组 h=0.1 N=floor(2/H) ALLOCATE(x(N+1), y(N+1)) !分配动态数组内存大小 x(1)=0 y(1)=-1 !迭代的初值 do i=0,N x(i+1)=x(i)+h y(i+1)=y(i)+h*f(x(i),y(i)) yc=y(i)+h*f(x(i+1),y(i+1)) y(i+1)=(y(i+1)+yc)/2 print*,y(i+1) enddo DEALLOCATE(x,y) !释放动态数组内存 CONTAINS real FUNCTION f(x,y) IMPLICIT NONE real, INTENT(in) :: x, y f=sqrt(x**2+y**2) ENDFUNCTION END PROGRAM test

没有代码环境导致有一部分( : ) 变成了笑脸
3楼2017-06-23 17:00:00
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

清泠之渊

新虫 (初入文坛)

引用回帖:
2楼: Originally posted by Yan_Jordan at 2017-06-23 16:57:50
首先 程序不全,没有f函数, 建议贴出错误信息。

从以上代码看,楼主对x y两个数组的定义(没有维度信息)很有问题,需要提前初始化好数组,维度应该是N+1(如果N不定,可以用动态数组)

我尝试猜测了下楼主的 ...

哇~厉害厉害!

发自小木虫IOS客户端
4楼2017-06-24 18:38:54
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
5楼2017-08-18 22:08:15
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 清泠之渊 的主题更新
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[基金申请] 情人节自我反思:在爱情中有过遗憾吗? +5 瞬息宇宙 2026-02-15 6/300 2026-02-18 12:51 by 月下雪林
[找工作] 售SCI一区文章,我:8 O5 51O 54,科目齐全,可+急 +3 i3cz6qj6l2 2026-02-17 3/150 2026-02-18 11:09 by lqtl9djx19
[考博] 售SCI一区文章,我:8 O5 51O 54,科目齐全,可+急 +3 i3cz6qj6l2 2026-02-17 3/150 2026-02-18 10:54 by lqtl9djx19
[考研] 售SCI一区文章,我:8 O5 51O 54,科目齐全,可+急 +3 i3cz6qj6l2 2026-02-17 3/150 2026-02-18 10:39 by lqtl9djx19
[考研] 售SCI一区文章,我:8 O5 51O 54,科目齐全,可+急 +3 pnpwoqbg8f 2026-02-17 3/150 2026-02-18 08:53 by lqtl9djx19
[硕博家园] 售SCI一区文章,我:8 O5 51O 54,科目齐全,可+急 +3 pnpwoqbg8f 2026-02-17 3/150 2026-02-18 08:38 by lqtl9djx19
[找工作] 售SCI一区文章,我:8 O5 51O 54,科目齐全,可+急 +4 pnpwoqbg8f 2026-02-17 4/200 2026-02-18 07:55 by lotyj5cz79
[基金申请] 售SCI一区文章,我:8 O5 51O 54,科目齐全,可+急 +3 pnpwoqbg8f 2026-02-16 4/200 2026-02-18 07:40 by lotyj5cz79
[考研] 售SCI一区文章,我:8 O5 51O 54,科目齐全,可+急 +4 pnpwoqbg8f 2026-02-16 4/200 2026-02-18 07:38 by lotyj5cz79
[硕博家园] 售SCI一区文章,我:8 O5 51O 54,科目齐全,可+急 +4 pnpwoqbg8f 2026-02-16 4/200 2026-02-18 07:23 by lotyj5cz79
[论文投稿] 售SCI一区文章,我:8 O5 51O 54,科目齐全,可+急 +4 pnpwoqbg8f 2026-02-16 4/200 2026-02-18 07:08 by lotyj5cz79
[公派出国] 售SCI一区文章,我:8 O5 51O 54,科目齐全,可+急 +3 pnpwoqbg8f 2026-02-16 3/150 2026-02-18 06:53 by lotyj5cz79
[论文投稿] 售SCI一区文章,我:8 O5 51O 54,科目齐全,可+急 +3 pnpwoqbg8f 2026-02-17 3/150 2026-02-18 00:40 by tk2gfblvuz
[找工作] 售SCI一区文章,我:8 O5 51O 54,科目齐全,可+急 +3 pnpwoqbg8f 2026-02-17 4/200 2026-02-18 00:23 by tk2gfblvuz
[公派出国] 售SCI一区文章,我:8 O5 51O 54,科目齐全,可+急 +3 pnpwoqbg8f 2026-02-17 3/150 2026-02-17 23:40 by tk2gfblvuz
[基金申请] 基金正文30页指的是报告正文还是整个申请书 +3 successhe 2026-02-16 4/200 2026-02-17 20:56 by successhe
[基金申请] 今年春晚有几个节目很不错,点赞! +5 瞬息宇宙 2026-02-16 6/300 2026-02-17 12:49 by jymy19840415
[微米和纳米] 球磨粉体时遇到了大的问题,请指教! 10+3 6sbiam 2026-02-12 15/750 2026-02-16 15:03 by tgzxzqj
[基金申请] 过年走亲戚时感受到了所开私家车的鄙视链 +3 瞬息宇宙 2026-02-15 5/250 2026-02-16 14:23 by aspect3000
[硕博家园] 江汉大学解明教授课题组招博士研究生/博士后 +3 cleverlyy 2026-02-12 3/150 2026-02-12 21:02 by qsdf1
信息提示
请填处理意见