日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 人文社科 > 生活经验 >内容正文

生活经验

UVa 10180 - Rope Crisis in Ropeland!

發(fā)布時間:2023/11/27 生活经验 40 豆豆
生活随笔 收集整理的這篇文章主要介紹了 UVa 10180 - Rope Crisis in Ropeland! 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

題目鏈接:http://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&category=41&page=show_problem&problem=1121

題意:給出兩點坐標(biāo),用一條最短的線(曲線或者直線)連接起來,坐標(biāo)系中原點處有一個半徑為R的圓,連線不能穿過這個圓。

分析:

這題我WA了好幾次,原因是把double的坐標(biāo)搞成int了,o(╯□╰)o

 1 #include <cstdio>
 2 #include <cstdlib>
 3 #include <cmath>
 4 
 5 const double PI = acos( -1.0 );
 6 
 7 struct point
 8 {
 9     double x, y;
10 };
11 
12 point O;  //坐標(biāo)原點
13 
14 double Get_Dist( point &a, point &b )    //計算兩點間距離
15 {
16     return sqrt( (a.x - b.x)*(a.x - b.x) + (a.y - b.y )*(a.y - b.y) );
17 }
18 
19 double Get_Angle( double a, double b, double c )  //余弦定理求角度
20 {
21     return acos( (b*b + c*c - a*a) / (2*b*c) );
22 }
23 
24 bool check( point &m, point &n, double x, double y )  //判斷坐標(biāo)( x, y )是否在點 m, n 之間
25 {
26     double minx = m.x < n.x ? m.x : n.x;
27     double maxx = m.x > n.x ? m.x : n.x;
28     double miny = m.y < n.y ? m.y : n.y;
29     double maxy = m.y > n.y ? m.y : n.y;
30     return ( x > minx && x <= maxx && y >= miny && y <= maxy );
31 }
32 
33 bool Judge( point &m, point &n, double &R )           //判斷是否需要繞過圓
34 {
35     if ( m.x == n.x )                                 //特判與y軸平行的線
36     {
37         if ( abs(m.x) >= R ) return true;
38         else
39         {
40             if ( m.y * n.y > 0 ) return true;
41             else return false;
42         }
43     }
44     else if ( m.y == n.y )                             //特判與x軸平行的線
45     {
46         if ( abs(m.y) >= R ) return true;
47         else
48         {
49             if ( m.x * n.x > 0 ) return true;
50             else return false;
51         }
52     }
53 
54     double A = n.y - m.y;                              //兩點連成的直線,求直線方程一般式,計算A, B, C
55     double B = m.x - n.x;
56     double C = (n.x - m.x) * m.y - (n.y - m.y) * m.x;
57     double dis = abs(C)/ sqrt( A*A + B*B );            //原點到直線的距離
58     if ( dis >= R ) return true;
59     else
60     {
61         double kkk = (-A) / B;
62         double bbb = (-C) / B;
63         double xx = ( -bbb ) / ( kkk + 1.0 / kkk );
64         double yy = ( (-1.0) / kkk ) * xx;
65         if ( check( m, n, xx, yy ) ) return false;     //如果線段穿過圓
66         else return true;                              //如果線段不穿過圓
67     }
68 }
69 
70 int main()
71 {
72     int T;
73     double R;
74     point A, B;
75     O.x = 0;
76     O.y = 0;
77     scanf( "%d", &T );
78     while ( T-- )
79     {
80         scanf( "%lf%lf%lf%lf%lf", &A.x, &A.y, &B.x, &B.y, &R );
81 
82         if ( Judge(A, B, R) )                             //如果不需要繞過圓
83             printf( "%.3f\n", Get_Dist(A, B) );
84         else                                              //如果需要繞過圓
85         {
86             double L1 = Get_Dist(A, O);
87             double L2 = Get_Dist(B, O);
88             double LL1 = sqrt( L1*L1 - R*R );
89             double LL2 = sqrt( L2*L2 - R*R );
90             double angle = Get_Angle( Get_Dist(A, B), L1, L2 ) - acos( R/L1 ) - acos( R/L2 );
91             double ans = LL1 + LL2 + R * angle;
92             printf( "%.3f\n", ans );
93         }
94     }
95     return 0;
96 }

轉(zhuǎn)載于:https://www.cnblogs.com/GBRgbr/archive/2012/08/21/2649587.html

總結(jié)

以上是生活随笔為你收集整理的UVa 10180 - Rope Crisis in Ropeland!的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 国产最新在线观看 | 日韩在线中文字幕视频 | 一区中文字幕 | 村姑电影在线播放免费观看 | 日韩av在线免费看 | 亚洲精品高清视频在线观看 | 啪啪免费av | 91黄色在线观看 | 成年人在线观看网站 | 热久久中文 | 亚洲视频天天射 | 在线观看中文字幕一区二区 | 欧美一区二区免费 | 国产伊人精品 | 青青青草视频在线 | 亚洲最大在线观看 | 天天毛片| 人人爱人人射 | 九七伦理电影 | 一区二区三区精品视频在线观看 | 古代黄色一级片 | 国产又粗又大又硬 | 精品福利一区二区 | 精品福利视频一区二区 | 免费成人深夜 | 松本一香在线播放 | 久久99精品国产 | 精品久久久久久久久久久久久久久 | 在线观看网站av | 日韩高清欧美 | 久久久久久逼 | 久久在线视频 | 小泽玛利亚一区二区三区在线观看 | 天天操网址 | 国产一二精品 | 好吊妞无缓冲视频观看 | 花房姑娘免费观看全集 | 国产chinese中国hdxxxx | 综合激情久久 | 污视频免费网站 | 夜夜嗨av一区二区三区免费区 | 天天操天天插天天干 | xxx.国产| 精品国产va久久久久久久 | 中文字幕亚洲一区二区三区 | 成色网| 神马久久久久久久久 | 亚洲成人av免费 | 国产乱码久久久久久 | 日本亲近相奷中文字幕 | 久久久久国产精品熟女影院 | 三上悠亚ssⅰn939无码播放 | 日本美女黄网站 | 中文在线a∨在线 | aaaa视频 | 97精品国产97久久久久久免费 | 日韩av不卡一区 | 潮见百合子 | 亚洲综合激情网 | 嫩草视频在线观看 | 久久国产视频播放 | 国产性av | 国产黄色一级片 | 黄色aa级片 | 国产一区二区在线视频观看 | 欧美一级全黄 | 爱爱免费小视频 | 欧美日韩中文字幕在线观看 | 国产中文字幕一区 | 免费观看黄色小视频 | 被灌满精子的波多野结衣 | 日本护士做爰视频 | 亚洲欧美激情在线观看 | 国产不卡免费视频 | 别揉我奶头啊嗯一区二区 | 男人天堂怡红院 | 黄色一级大片在线免费看国产一 | 香蕉视频黄色在线观看 | 国产高清sp| 成人羞羞在线观看网站 | 亚洲日本在线观看视频 | 性生交大片免费看3p | 日本在线中文字幕专区 | 半推半就一ⅹ99av | 伦一理一级一a一片 | 日本一区二区免费电影 | 精品免费av | 熟女丝袜一区 | 国产福利一区二区三区 | 亚洲清纯唯美 | 国产偷人妻精品一区 | 日本激情小视频 | www视频免费观看 | 精品国产一区二区三区四区 | 九九九九热 | 女女h百合无遮羞羞漫画软件 | 成人免费在线播放视频 | 日韩专区中文字幕 | www婷婷av久久久影片 |