社区
数据结构与算法
帖子详情
请教高手!有人了解龙格-库塔吗?
Robby1984
2005-10-20 08:44:45
请教高手!有人了解龙格-库塔吗?用这个怎么编程,语言不限
...全文
130
3
打赏
收藏
请教高手!有人了解龙格-库塔吗?
请教高手!有人了解龙格-库塔吗?用这个怎么编程,语言不限
复制链接
扫一扫
分享
转发到动态
举报
写回复
配置赞助广告
用AI写文章
3 条
回复
切换为时间正序
请发表友善的回复…
发表回复
打赏红包
zachary7833
2005-10-22
打赏
举报
回复
数值分析书上有。
mmmcd
2005-10-20
打赏
举报
回复
来自:
http://spaces.msn.com/members/zwill/
2005-7-6
龙格-库塔方法
#include<stdlib.h>
#include<stdio.h>
/*n表示几等分,n+1表示他输出的个数*/
int RungeKutta(double y0,double a,double b,int n,double *x,double *y,int style,double (*function)(double,double))
{
double h=(b-a)/n,k1,k2,k3,k4;
int i;
// x=(double*)malloc((n+1)*sizeof(double));
// y=(double*)malloc((n+1)*sizeof(double));
x[0]=a;
y[0]=y0;
switch(style)
{
case 2:
for(i=0;i<n;i++)
{
x[i+1]=x[i]+h;
k1=function(x[i],y[i]);
k2=function(x[i]+h/2,y[i]+h*k1/2);
y[i+1]=y[i]+h*k2;
}
break;
case 3:
for(i=0;i<n;i++)
{
x[i+1]=x[i]+h;
k1=function(x[i],y[i]);
k2=function(x[i]+h/2,y[i]+h*k1/2);
k3=function(x[i]+h,y[i]-h*k1+2*h*k2);
y[i+1]=y[i]+h*(k1+4*k2+k3)/6;
}
break;
case 4:
for(i=0;i<n;i++)
{
x[i+1]=x[i]+h;
k1=function(x[i],y[i]);
k2=function(x[i]+h/2,y[i]+h*k1/2);
k3=function(x[i]+h/2,y[i]+h*k2/2);
k4=function(x[i]+h,y[i]+h*k3);
y[i+1]=y[i]+h*(k1+2*k2+2*k3+k4)/6;
}
break;
default:
return 0;
}
return 1;
}
double function(double x,double y)
{
return y-2*x/y;
}
//例子求y'=y-2*x/y(0<x<1);y0=1;
/*
int main()
{
double x[6],y[6];
printf("用二阶龙格-库塔方法\n");
RungeKutta(1,0,1,5,x,y,2,function);
for(int i=0;i<6;i++)
printf("x[%d]=%f,y[%d]=%f\n",i,x[i],i,y[i]);
printf("用三阶龙格-库塔方法\n");
RungeKutta(1,0,1,5,x,y,3,function);
for(i=0;i<6;i++)
printf("x[%d]=%f,y[%d]=%f\n",i,x[i],i,y[i]);
printf("用四阶龙格-库塔方法\n");
RungeKutta(1,0,1,5,x,y,4,function);
for(i=0;i<6;i++)
printf("x[%d]=%f,y[%d]=%f\n",i,x[i],i,y[i]);
return 1;
}
tanyu7294
2005-10-20
打赏
举报
回复
不了解,帮不了你。
RK_
龙格
-
库塔
_matlab_源码
文件夹里是matlab
龙格
库塔
法,可用来求解常微分方程,
龙格
-
库塔
方法
对
龙格
-
库塔
方法进行了详尽的介绍,里面的大多内容对求解微分方程有指导作用
(精品word)MATLAB
龙格
-
库塔
方法解微分方程.doc
(精品word)MATLAB
龙格
-
库塔
方法解微分方程.doc
C语言实现
龙格
-
库塔
C语言实现
龙格
-
库塔
计算方法的实验题目 难度不小
Matlab求解常微分方程初值问题 欧拉方法 梯形方法
龙格
-
库塔
方法
(数值分析课程设计)Matlab求解常微分方程初值问题 欧拉方法 梯形方法
龙格
-
库塔
方法
数据结构与算法
33,028
社区成员
35,337
社区内容
发帖
与我相关
我的任务
数据结构与算法
数据结构与算法相关内容讨论专区
复制链接
扫一扫
分享
社区描述
数据结构与算法相关内容讨论专区
社区管理员
加入社区
获取链接或二维码
近7日
近30日
至今
加载中
查看更多榜单
社区公告
暂无公告
试试用AI创作助手写篇文章吧
+ 用AI写文章