| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 415 人关注过本帖
标题:编译没有错误,要错就是逻辑的错误,希望懂的人指点一下-求不规则图形面积
只看楼主 加入收藏
梁朝斌
Rank: 4
等 级:业余侠客
帖 子:192
专家分:288
注 册:2012-10-21
结帖率:100%
收藏
已结贴  问题点数:20 回复次数:3 
编译没有错误,要错就是逻辑的错误,希望懂的人指点一下-求不规则图形面积
#include
#include
#define maxsize 100
#define eps 0.000001
int main(void)
{
    double a,b,t,x[maxsize],step,s0,s1;
    double f(double m);
    int i,n;

    printf("please input a= and b=\n");
    scanf("%lf  %lf",&a,&b);

    n=1;
    s0=(f(a)+f(b))*(b-a)/2;
    do
    {
        n++;
        step=(b-a)/n;
        for(i=0;i<=n;i++)
        {
            x[i]=a+i*step;
            s1=0;
            
            for(i=1;i<=n;i++)
                s1+=(f(x[i+1])+f(x[i]))*step/2;
            t=s0;
            s0=s1;
            
        }
    }
    while (fabs(s0-t)>eps);
    {
        printf("s0=%lf\n",s0);
        printf("此时步长为:%d",n);
        printf("\n");
    }
    return 0;
}
double f(double m)
{
    double y;
    y=sqrt(1+pow(m,2));
    return y;
}
    这是数值分析或者计算方法里面:数值积分与数值微分里面的题目,求积分的近似值 。把不规则的图形换成梯形,然后将梯形分割成若干个小梯形,使小梯形相加,最后近似的求出不规则图形的面积

   
搜索更多相关主题的帖子: please include 
2012-11-21 22:33
heroinearth
Rank: 10Rank: 10Rank: 10
来 自:云南曲靖
等 级:青峰侠
帖 子:430
专家分:1506
注 册:2011-10-24
收藏
得分:7 
你这没有注释说明很不好理解,只能给你提点思路:
你既然把不规则图形分成n个小梯形,你就应求出x0,x1对应的y0,y1,y0 y1就是两条边的长,x1-x0就是高,梯形面积=(顶边+底边)*高/2,把n个小梯形面积加起来就是近似值
2012-11-22 00:23
一个孩子
Rank: 8Rank: 8
等 级:蝙蝠侠
威 望:5
帖 子:356
专家分:954
注 册:2012-10-1
收藏
得分:7 
直接用积分求解不行吗?

重要的不是结果,是求一个结果的过程,哪怕千难万难,当你有想要的结果时,你已走的很远
2012-11-22 10:29
youngdavid
Rank: 7Rank: 7Rank: 7
等 级:黑侠
帖 子:107
专家分:698
注 册:2012-9-24
收藏
得分:7 
楼主代码有点小问题
do
    {
        n++;
        step=(b-a)/n;
        for(i=0;i<=n;i++)
        {
            x[i]=a+i*step;
            s1=0;
           
            for(i=1;i<=n;i++)
                s1+=(f(x[i+1])+f(x[i]))*step/2;
            t=s0;
            s0=s1;
           
        }
    }
这里面内层for循环运行到最后的时候x[i+1]超出输入设定的界限了,另外比如n=20对于某一个外层for循环i=5,内层for循环x[i]中i从6到20是没有赋值的,为随机值,所以会运行出错。
2012-11-22 20:53
快速回复:编译没有错误,要错就是逻辑的错误,希望懂的人指点一下-求不规则图形 ...
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.016490 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved