• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            /**
              復化Simpson積分  
                                                                              m-1                   m-1
             復化Simpson公式: Tn = (h/3) *  { f(a)/2  +  4 * ∑ f ( x2i  + 2 * ∑ f ( x2i+1 ) +  f(b)/2 )} 
                                                                              i=0                     i=1
             步長: h=b-a/n,  n=2*m

             屬性: 數值積分法

            《數值計算方法與算法》-2 Editon -科學出版社 P55
               
             代碼維護:2007.04.20   pengkuny
            **/ 

            #include<iostream>
            #include
            <cmath>

            using namespace std;

            #define f(x) (sin(x))  //舉例函數
            #define epsilon 0.00001  //精度

            //復化Simpson公式
            float Simpson(float aa, float bb, long n)
            {//aa,bb:端點  n,分區數
                if (!(n%2)) //保證n為偶數
                    n = n+1;
                
            long m = n/2;

                
            float sum = 0;
                
            float h = (bb-aa)/n; //步長

                
            float sum1 = 0, sum2 = 0;
                
            for (long i=0; i<m; i++)
                
            {
                    sum1 
            += f(aa + (2*i+1)*h);
                }

                
            for (long i=1; i<m; i++)
                
            {
                    sum2 
            += f(aa + (2*i)*h);
                }


                sum 
            = f(aa) + f(bb) + 2*sum2 + 4*sum1;

                
            return (h*sum/3);
            }



            int main()
            {
                
            float a,b;
                
            long n;
                cout
            <<"復化Simpson積分,請輸入積分范圍a,b:"<<endl;
                cin
            >>a>>b;
                cout
            <<"請輸入分割區間數n:"<<endl;
                cin
            >>n;

                cout
            <<"積分結果:"<<Simpson(a, b, n)<<endl;

                system(
            "pause");
                
            return 0;
            }


             

            posted on 2007-04-20 10:55 哈哈 閱讀(1514) 評論(3)  編輯 收藏 引用

            評論:
            # re: 復化Simpson積分 2007-11-26 20:13 | 網友
            題目中的精度好像沒有用  回復  更多評論
              
            # re: 復化Simpson積分 2008-12-28 20:30 |
            @網友
            i重復初始化了  回復  更多評論
              
            # re: 復化Simpson積分 2009-09-05 11:22 | zh
            保證n為偶數,書寫錯誤!上面的n變為恒是奇數了  回復  更多評論
              
            久久久久人妻一区精品| 青青草原精品99久久精品66| 国内精品久久国产大陆| 青青草国产精品久久| 97精品伊人久久大香线蕉| 久久精品亚洲一区二区三区浴池| 久久免费高清视频| 亚洲人成网站999久久久综合| 一级A毛片免费观看久久精品| 久久久久久久久久久久中文字幕| 久久精品免费一区二区三区| 怡红院日本一道日本久久 | 久久婷婷激情综合色综合俺也去| 久久99热只有频精品8| 亚洲精品无码久久不卡| 久久国产亚洲精品无码| 久久99国产精品久久99小说 | 草草久久久无码国产专区| 国产A级毛片久久久精品毛片| 久久99精品久久久久久| 一本一本久久A久久综合精品| 欧美激情精品久久久久久久九九九| 久久永久免费人妻精品下载| 日产精品久久久久久久| 九九久久精品无码专区| 亚洲国产精品婷婷久久| 99久久99久久久精品齐齐| 99久久精品国产一区二区| 久久影视综合亚洲| 久久精品二区| 无码国内精品久久人妻麻豆按摩| 久久综合中文字幕| 99热精品久久只有精品| 91久久精品无码一区二区毛片| 99久久er这里只有精品18| 国产精品久久久久国产A级| 久久久久高潮毛片免费全部播放 | 国产精品久久久久a影院| 久久亚洲视频| 久久精品免费一区二区| 三上悠亚久久精品|