2#include3#include4#include5#include6#include78#defineN5209#defineEPS1e-6101" />

欧美三区_成人在线免费观看视频_欧美极品少妇xxxxⅹ免费视频_a级毛片免费播放_鲁一鲁中文字幕久久_亚洲一级特黄

BZOJ 1502 月下檸檬樹 simpson積分

系統 1863 0

題解:
投在地上的影子是很多圓和兩圓公切線組成的梯形的面積并。

PS:圓只要和地面平行,無論光從哪個角度照射,投影都是圓

?

其實應該一開始應先分成若干份做simpson的。。

View Code
        
           1
        
         #include <iostream>


        
           2
        
         #include <cstring>


        
           3
        
         #include <cstdio>


        
           4
        
         #include <cstdlib>


        
           5
        
         #include <algorithm>


        
           6
        
         #include <cmath>


        
           7
        
        
           8
        
        
          #define
        
         N 520


        
           9
        
        
          #define
        
         EPS 1e-6


        
          10
        
        
          11
        
        
          using
        
        
          namespace
        
        
           std;


        
        
          12
        
        
          13
        
        
          int
        
        
           n;


        
        
          14
        
        
          double
        
        
           a[N],b[N],af,h,lt,rt;


        
        
          15
        
        
          16
        
        
          struct
        
        
           C


        
        
          17
        
        
          {


        
        
          18
        
        
          double
        
        
           x,y,p,q;


        
        
          19
        
        
          }c[N];


        
        
          20
        
        
          21
        
         inline 
        
          int
        
         dc(
        
          double
        
        
           x)


        
        
          22
        
        
          {


        
        
          23
        
        
          if
        
        (x>EPS) 
        
          return
        
        
          1
        
        
          ;


        
        
          24
        
        
          else
        
        
          if
        
        (x<-EPS) 
        
          return
        
         -
        
          1
        
        
          ;


        
        
          25
        
        
          return
        
        
          0
        
        
          ;


        
        
          26
        
        
          }


        
        
          27
        
        
          28
        
         inline 
        
          void
        
        
           read()


        
        
          29
        
        
          {


        
        
          30
        
             scanf(
        
          "
        
        
          %d%lf
        
        
          "
        
        ,&n,&
        
          af);


        
        
          31
        
             af=
        
          1
        
        /
        
          tan(af);


        
        
          32
        
        
          for
        
        (
        
          int
        
         i=
        
          1
        
        ;i<=n+
        
          1
        
        ;i++
        
          )


        
        
          33
        
        
              {


        
        
          34
        
                 scanf(
        
          "
        
        
          %lf
        
        
          "
        
        ,&
        
          a[i]);


        
        
          35
        
                 h+=a[i]; a[i]=h*
        
          af;


        
        
          36
        
        
              }


        
        
          37
        
             lt=a[
        
          1
        
        ];rt=a[n+
        
          1
        
        
          ];


        
        
          38
        
        
          for
        
        (
        
          int
        
         i=
        
          1
        
        ;i<=n;i++
        
          )


        
        
          39
        
        
              {


        
        
          40
        
                 scanf(
        
          "
        
        
          %lf
        
        
          "
        
        ,&
        
          b[i]);


        
        
          41
        
                 lt=min(lt,a[i]-
        
          b[i]);


        
        
          42
        
                 rt=max(rt,a[i]+
        
          b[i]);


        
        
          43
        
        
              }


        
        
          44
        
        
          }


        
        
          45
        
        
          46
        
         inline 
        
          void
        
        
           calc()


        
        
          47
        
        
          {


        
        
          48
        
        
          for
        
        (
        
          int
        
         i=
        
          1
        
        ;i<=n;i++
        
          )


        
        
          49
        
        
          if
        
        (a[i+
        
          1
        
        ]-a[i]>fabs(b[i+
        
          1
        
        ]-
        
          b[i]))


        
        
          50
        
        
                  {


        
        
          51
        
                     c[i].x=a[i]+b[i]*(b[i]-b[i+
        
          1
        
        ])/(a[i+
        
          1
        
        ]-
        
          a[i]);


        
        
          52
        
                     c[i].y=sqrt(b[i]*b[i]-(c[i].x-a[i])*(c[i].x-
        
          a[i]));


        
        
          53
        
                     c[i].p=a[i+
        
          1
        
        ]+b[i+
        
          1
        
        ]*(b[i]-b[i+
        
          1
        
        ])/(a[i+
        
          1
        
        ]-
        
          a[i]);


        
        
          54
        
                     c[i].q=sqrt(b[i+
        
          1
        
        ]*b[i+
        
          1
        
        ]-(c[i].p-a[i+
        
          1
        
        ])*(c[i].p-a[i+
        
          1
        
        
          ]));


        
        
          55
        
        
                  }


        
        
          56
        
        
          }


        
        
          57
        
        
          58
        
         inline 
        
          double
        
         f(
        
          double
        
        
           p)


        
        
          59
        
        
          {


        
        
          60
        
        
          double
        
         res=
        
          0
        
        
          ;


        
        
          61
        
        
          for
        
        (
        
          int
        
         i=
        
          1
        
        ;i<=n;i++
        
          )


        
        
          62
        
        
              {


        
        
          63
        
        
          if
        
        (fabs(a[i]-p)<b[i]) res=max(res,sqrt(b[i]*b[i]-(a[i]-p)*(a[i]-
        
          p)));


        
        
          64
        
        
          if
        
        (p>c[i].x&&p<c[i].p) res=max(res,c[i].y-(p-c[i].x)*(c[i].y-c[i].q)/(c[i].p-
        
          c[i].x));


        
        
          65
        
        
              }


        
        
          66
        
        
          return
        
        
           res;


        
        
          67
        
        
          }


        
        
          68
        
        
          69
        
         inline 
        
          double
        
         simpson(
        
          double
        
         l,
        
          double
        
         r,
        
          double
        
         fl,
        
          double
        
         fmid,
        
          double
        
        
           fr)


        
        
          70
        
        
          {


        
        
          71
        
        
          return
        
         (fl+fr+
        
          4
        
        *fmid)*(r-l)/
        
          6
        
        
          ;


        
        
          72
        
        
          }


        
        
          73
        
        
          74
        
         inline 
        
          double
        
         rsimpson(
        
          double
        
         l,
        
          double
        
         r,
        
          double
        
         fl,
        
          double
        
         fmid,
        
          double
        
        
           fr)


        
        
          75
        
        
          {


        
        
          76
        
        
          double
        
        
           p,q,mid,x,y,z;


        
        
          77
        
             mid=(l+r)/
        
          2
        
        
          ;


        
        
          78
        
             p=f((l+mid)/
        
          2
        
        ); q=f((mid+r)/
        
          2
        
        
          );


        
        
          79
        
             x=simpson(l,r,fl,fmid,fr); y=simpson(l,mid,fl,p,fmid); z=
        
          simpson(mid,r,fmid,q,fr);


        
        
          80
        
        
          if
        
        (dc(fabs(x-y-z))==
        
          0
        
        ) 
        
          return
        
         y+
        
          z;


        
        
          81
        
        
          else
        
        
          return
        
         rsimpson(l,mid,fl,p,fmid)+
        
          rsimpson(mid,r,fmid,q,fr);


        
        
          82
        
        
          }


        
        
          83
        
        
          84
        
         inline 
        
          void
        
        
           go()


        
        
          85
        
        
          {


        
        
          86
        
        
              calc();


        
        
          87
        
             printf(
        
          "
        
        
          %.2lf\n
        
        
          "
        
        ,
        
          2
        
        *rsimpson(lt,rt,
        
          0
        
        ,f(lt+rt)/
        
          2
        
        ,
        
          0
        
        
          ));


        
        
          88
        
        
          }


        
        
          89
        
        
          90
        
        
          int
        
        
           main()


        
        
          91
        
        
          {


        
        
          92
        
        
              read(),go();


        
        
          93
        
        
          return
        
        
          0
        
        
          ;


        
        
          94
        
         }
      

?

?

BZOJ 1502 月下檸檬樹 simpson積分


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 亚洲精品成人av在线 | 午夜色视频在线观看 | 亚洲国产欧洲精品路线久久 | 四虎影视免费在线观看 | 久久91av| 日韩精品在线一区 | 日本精品久久久久中文字幕2 | 欧美国产日韩在线 | 男女男精品视频免费观看 | 日韩精品亚洲专区在线电影不卡 | www视频在线观看 | 超碰97最新 | av天空 | 日韩a在线看免费观看视频 五月天激情视频在线观看 成人97在线观看免费高清 | 欧美国产中文字幕 | 精品成人佐山爱一区二区 | 日本一区二区三区高清不卡 | 黄页网站免费高清在线观看 | 亚洲国产一区二区三区四区五区 | 国产精品色综合久久 | 孕妇体内谢精满日本电影 | 天天操综合网 | 国产一区二区三区福利 | 中文字幕欧美在线 | 久久99精品久久久久久 | 日本久久综合网 | 日本午夜大片免费观看视频 | 精品国产福利片在线观看 | 精品一区二区三区在线观看视频 | 毛片短视频 | 欧美成人激情 | 日本高清乱理伦片中文字幕啊 | 极品尤物一区二区三区 | 国产亚洲欧美在线 | 国产乱码精品一区二区三区五月婷 | 欧美一区二区三区中文字幕 | 日韩大片免费看 | 欧美精彩视频 | 精品欧美高清一区二区免费 | 色七七网站 | 久久久久久久一区二区 |