青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

Why so serious? --[NKU]schindlerlee

zju2589 不重合的n個圓形成的區域


??1?/*?
??2??*?SOUR:zju2589
??3??*?ALGO:computational?geomtry?計算平面上不重合的n個圓形成的區域
??4??*?基本的方法,如圖所示,將所有圓之間的交點作為點,將在同一個圓上的所有交點之間的弧作
??5??*?為邊建立一張有向圖,之后可以利用平面圖的歐拉定理
??6??*???????????V?-?E?+?F?=?2
??7??*?由于V已知,E已知,F就可以求出來了。
??8??*?由于歐拉定理是對一張無向連通圖成立的,如果圖有多個連通塊的時候需要對歐拉定理做一些
??9??*?修改。由于多個有向圖的面共享最外邊的面,所以設聯通塊的個數為n
?10??*?V?-?E?+?F?=?2?*?n?,?但是需要減去n個聯通塊共享的最大平面
?11??*?所以?F?=?n?+?1?+?E?-?V;
?12??*?DATE:?2010年?07月?08日?星期四?14:49:41?CST
?13??*?COMM:5
?14??*?*/
?15?const?int?N?=?64;
?16?const?double?eps?=?1e-8;
?17?int?n,?vis[N],?g[N][N];
?18?double?r[N];
?19?struct?point_t?{
?20?????double?x,?y;
?21?????point_t(){}
?22?????point_t(double?a,?double?b){x?=?a,?y?=?b;}?
?23?}c[N];
?24?
?25?int?dcmp(double?x)?{?return?(x?>?eps)?-?(x?<?-eps);}?
?26?bool?operator?<?(point_t?a,point_t?b)?
?27?{
?28???if?(dcmp(a.x?-?b.x))?{
?29???????return?a.x?<?b.x;
?30???}
?31???return?dcmp(a.y?-?b.y)?<?0;
?32?}
?33?
?34?point_t?operator?+?(point_t?a,?point_t?b)?{?return?point_t(a.x+b.x,?a.y+b.y);}
?35?point_t?operator?-?(point_t?a,?point_t?b)?{?return?point_t(a.x-b.x,?a.y-b.y);}
?36?double?dist(point_t?a,?point_t?b)?{?return?hypot(a.x-b.x,?a.y-b.y);}
?37?double?sqr(double?x)?{?return?x?*?x;}
?38?point_t?normal(point_t?a)?{?return?point_t(a.x?/?hypot(a.x,?a.y),?a.y?/?hypot(a.x,?a.y));}
?39?point_t?scale(point_t?a,?double?fac)?{?return?point_t(a.x?*?fac,?a.y?*?fac);}
?40?bool?intersect(point_t?c1,?double?r1,?point_t?c2,?double?r2,?point_t?&a,?point_t?&b)
?41?{
?42???double?d?=?dist(c1,?c2);
?43???if?(d?<?fabs(r1?-?r2)?-?eps?||?d?>?r1?+?r2?+?eps)?{
?44???????return?false;
?45???}
?46???double?len?=?(sqr(r1)?-?sqr(r2)?+?sqr(d))?/?2.0?/?d;
?47???double?h?=?sqrt(sqr(r1)?-?sqr(len));
?48???point_t?t?=?normal(c2?-?c1);
?49???point_t?p?=?c1?+?scale(t,?len);
?50???point_t?v?=?scale(point_t(-t.y,?t.x),?h);
?51???a?=?p?+?v,?b?=?p?-v;
?52???return?true;
?53?}
?54?
?55?void?init()
?56?{
?57???int?i;
?58???memset(g,?0,?sizeof(g));
?59???memset(vis,?0,?sizeof(vis));
?60???for?(i?=?0;i?<?n;i++)?{
?61???????g[i][i]?=?1;
?62???}
?63?}
?64?
?65?int?main()
?66?{
?67???int?testcase,?i,?j,?k;
?68???scanf("%d",?&testcase);
?69???while?(testcase--)?{
?70???????scanf("%d",?&n);
?71???????set?<point_t>?allpoint,?p[64];
?72???????for?(i?=?0;i?<?n;i++)?{
?73???????????scanf("%lf?%lf?%lf",?&c[i].x,?&c[i].y,?&r[i]);
?74???????}
?75???????init();
?76???????for?(i?=?0;i?<?n;i++)?{
?77???????????for?(j?=?i?+?1;j?<?n;j++)?{
?78???????????????point_t?a,?b;
?79???????????????if?(intersect(c[i],?r[i],?c[j],?r[j],?a,?b))?{
?80???????????????????allpoint.insert(a),?allpoint.insert(b);
?81???????????????????p[i].insert(a),?p[i].insert(b);
?82???????????????????p[j].insert(a),?p[j].insert(b);
?83???????????????????g[i][j]?=?g[j][i]?=?1;
?84???????????????}
?85???????????}
?86???????}
?87???????for?(k?=?0;k?<?n;k++)?{
?88???????????for?(i?=?0;i?<?n;i++)?{
?89???????????????for?(j?=?0;j?<?n;j++)?{
?90???????????????????g[i][j]?|=?g[i][k]?&?g[k][j];
?91???????????????}
?92???????????}
?93???????}
?94???????int?f?=?1;
?95???????for?(i?=?0;i?<?n;i++)?{
?96???????????f?+=?p[i].size();
?97???????????if?(!vis[i])?{
?98???????????????f?+=?1;
?99???????????????for?(j?=?0;j?<?n;j++)?{
100???????????????????vis[j]?|=?g[i][j];
101???????????????}
102???????????}
103???????}
104???????f?-=?allpoint.size();
105???????printf("%d\n",?f);
106???}?
107???return?0;
108?}
109?
110?

posted on 2010-07-08 22:06 schindlerlee 閱讀(1756) 評論(0)  編輯 收藏 引用 所屬分類: 解題報告

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲成人在线视频网站| 久久亚洲美女| 欧美电影免费观看| 久久午夜激情| 久久er精品视频| 久久乐国产精品| 免费成人网www| 亚洲第一福利视频| 亚洲国产婷婷| 中文国产一区| 久久国产精品免费一区| 久热国产精品视频| 欧美精品一区三区| 国产精品美女黄网| 亚洲高清在线精品| 亚洲伊人久久综合| 久久综合成人精品亚洲另类欧美| 欧美成人有码| 亚洲一区二区三区影院| 噜噜噜噜噜久久久久久91| 欧美日韩三级视频| 精品福利av| 亚洲欧美自拍偷拍| 亚洲福利精品| 欧美在线视屏| 欧美性猛交视频| 亚洲国产成人av| 午夜精品99久久免费| 欧美高清视频免费观看| 宅男精品视频| 欧美成人午夜| 国模套图日韩精品一区二区| 亚洲午夜羞羞片| 欧美96在线丨欧| 亚洲欧美在线一区| 欧美日韩久久| 亚洲国产视频直播| 久久久999精品免费| 中日韩视频在线观看| 欧美成人高清| 久久久久免费观看| 99国产精品久久久久久久| 久久久免费av| 国产亚洲精品久久久久婷婷瑜伽 | 欧美成人精品高清在线播放| 国产精品视频一| 一本久久a久久免费精品不卡| 国产精品wwwwww| 久久这里有精品15一区二区三区| 国产精品美女www爽爽爽| 亚洲乱亚洲高清| 欧美顶级少妇做爰| 久久精品午夜| 国产一区二区丝袜高跟鞋图片| 亚洲一区欧美二区| 99视频精品全国免费| 欧美人交a欧美精品| 亚洲免费成人av| 亚洲激情第一区| 欧美成人一区二区三区在线观看| 一区二区在线观看视频| 久久婷婷丁香| 久久免费精品日本久久中文字幕| 国产在线不卡精品| 久久综合福利| 免费观看成人www动漫视频| 伊人久久综合| 欧美激情无毛| 欧美黄色大片网站| 国产精品99久久不卡二区| 99亚洲视频| 国产精品日韩专区| 久久久久久伊人| 另类欧美日韩国产在线| 亚洲精品久久在线| 日韩亚洲在线| 国产精品一区2区| 久久精品亚洲| 麻豆精品精华液| 国产精品99久久不卡二区| 亚洲主播在线| 亚洲大胆在线| 中国女人久久久| 精品成人一区二区| 亚洲精品中文字幕有码专区| 国产精品久久久久久久久搜平片 | 欧美一级视频免费在线观看| 午夜影视日本亚洲欧洲精品| 激情久久一区| av成人黄色| 韩国三级电影一区二区| 欧美日韩亚洲视频一区| 亚洲尤物在线| 久久香蕉国产线看观看网| 亚洲视频免费| 久久久久久久综合日本| 一区二区久久| 久久精品国产欧美亚洲人人爽| 亚洲精品一区二区三区99| 国产精品99久久不卡二区| 在线不卡亚洲| 亚洲欧美网站| 亚洲天堂成人在线视频| 久久裸体艺术| 午夜精品短视频| 欧美理论电影网| 麻豆国产精品一区二区三区 | 一区二区三区欧美激情| 欧美三级电影网| 久久婷婷国产综合精品青草| 欧美日韩国产在线| 免费亚洲一区二区| 国产欧美日韩综合| 亚洲精品日韩在线观看| 激情综合激情| 亚洲女性裸体视频| 在线亚洲观看| 欧美高清在线| 欧美成人高清视频| 亚洲大黄网站| 久久亚洲美女| 免费亚洲网站| 影音先锋亚洲一区| 欧美在线观看视频一区二区三区| 亚洲综合国产精品| 欧美日韩一区二区三| 亚洲黑丝一区二区| 亚洲欧洲日韩在线| 美女福利精品视频| 亚洲第一页在线| 最近中文字幕日韩精品| 久久蜜桃资源一区二区老牛 | 国产欧美在线看| 午夜精品免费在线| 久久久久.com| 国际精品欧美精品| 久久精视频免费在线久久完整在线看| 午夜在线播放视频欧美| 国产九九精品视频| 亚洲欧美乱综合| 欧美一区二区日韩一区二区| 国产精品永久免费观看| 亚洲一区二区欧美| 欧美一区二区啪啪| 国内久久婷婷综合| 亚洲精品孕妇| 欧美激情二区三区| 亚洲免费高清| 亚洲免费视频网站| 国产日韩精品一区二区浪潮av| 国产精品99久久久久久久久久久久| 亚洲图色在线| 国产伦一区二区三区色一情| 午夜一级在线看亚洲| 老鸭窝毛片一区二区三区| 亚洲成色精品| 欧美人在线视频| 中文精品在线| 久久免费视频观看| 亚洲日本中文字幕| 国产精品福利在线| 久久久精品国产99久久精品芒果| 欧美阿v一级看视频| 99综合电影在线视频| 国产欧美大片| 欧美成人一区二区| 亚洲综合首页| 亚洲国产精品ⅴa在线观看 | 久久一区欧美| 99视频超级精品| 女同性一区二区三区人了人一| 亚洲国产老妈| 午夜视频在线观看一区二区三区| 国产精品一区二区三区观看| 久久激情五月丁香伊人| 亚洲国产小视频在线观看| 香蕉国产精品偷在线观看不卡| 黑丝一区二区| 国产精品高清网站| 开心色5月久久精品| 这里只有精品视频在线| 狂野欧美一区| 午夜国产精品影院在线观看| 亚洲二区精品| 国产亚洲aⅴaaaaaa毛片| 欧美男人的天堂| 久热精品视频在线观看一区| 亚洲午夜精品一区二区| 欧美 日韩 国产一区二区在线视频| 亚洲特色特黄| 亚洲精品久久久久久久久久久| 国产亚洲综合性久久久影院| 欧美日韩精品伦理作品在线免费观看| 欧美伊人久久大香线蕉综合69| 99在线精品视频| 亚洲精品在线电影| 91久久黄色| 欧美黄色一区二区| 麻豆免费精品视频| 久久一区二区三区av|