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

應用平面圖的歐拉定理:V + F - E = 2
兩兩線段求交,得到交點數 V,然后判斷每個交點落在幾條邊上,如果一個點在一條邊上,這條邊就分裂成兩條邊,邊數加 1。這樣得到邊數 E。最后直接用歐拉定理解得 F。


/*************************************************************************
Author: WHU_GCC
Created Time: 2007-8-20 12:52:55
File Name: pku2284.cpp
Description: 
***********************************************************************
*/

#include 
<iostream>
#include 
<cmath>
using namespace std;
#define out(x) (cout<<#x<<": "<<x<<endl)
const int maxint=0x7FFFFFFF;
typedef 
long long int64;
const int64 maxint64 = 0x7FFFFFFFFFFFFFFFLL;
template
<class T>void show(T a, int n){for(int i=0; i<n; ++i) cout<<a[i]<<' '; cout<<endl;}
template
<class T>void show(T a, int r, int l){for(int i=0; i<r; ++i)show(a[i],l);cout<<endl;}

const double INF = 1e200;
const double EP = 1e-10;

struct point_t
{
    
double x, y;
    point_t(
double a = 0double b = 0)
    
{
        x 
= a;
        y 
= b;
    }

}
;

struct lineseg_t
{
    point_t s, e;
    lineseg_t (point_t a, point_t b)
    
{
        s 
= a;
        e 
= b;
    }

    lineseg_t()
    
{}
}
;

struct line_t
{
    
double a, b, c;
}
;

bool operator <(point_t p1, point_t p2)
{
    
return p1.x < p2.x || p1.x == p2.x && p1.y < p2.y;
}



bool operator ==(point_t p1, point_t p2)
{
    
return abs(p1.x - p2.x) < EP && abs(p1.y - p2.y) < EP;
}


double multiply(point_t sp, point_t ep, point_t op)
{
    
return (sp.x - op.x) * (ep.y - op.y) - (ep.x - op.x) * (sp.y - op.y);
}


bool online(lineseg_t l, point_t p)
{
    
return abs(multiply(l.e, p, l.s)) < EP && (p.x - l.s.x) * (p.x - l.e.x) < EP && (p.y - l.s.y) * (p.y - l.e.y) < EP;
}


bool lineintersect(line_t l1, line_t l2, point_t &p)
{
    
double d = l1.a * l2.b - l2.a * l1.b;
    
if (abs(d) < EP) return false;
    p.x 
= (l2.c * l1.b - l1.c * l2.b) / d;
    p.y 
= (l2.a * l1.c - l1.a * l2.c) / d;
    
return true;
}


line_t makeline(point_t p1, point_t p2)
{
    line_t t1;
    
int sign = 1;
    t1.a 
= p2.y - p1.y;
    
if (t1.a < 0)
    
{
        sign 
= -1;
        t1.a 
= sign * t1.a;
    }

    t1.b 
= sign * (p1.x - p2.x);
    t1.c 
= sign * (p1.y * p2.x - p1.x * p2.y);
    
return t1;
}


bool intersection(lineseg_t l1, lineseg_t l2, point_t &p)
{
    line_t ll1, ll2;
    ll1 
= makeline(l1.s, l1.e);
    ll2 
= makeline(l2.s, l2.e);
    
if (lineintersect(ll1, ll2, p))
        
return online(l1, p) && online(l2, p);
    
else return false;
}


const int maxn = 100000;
point_t p[maxn];
int n;

point_t inter[maxn];
int cnt_inter;

int main()
{
    
int ca = 1;
    
while (scanf("%d"&n), n != 0)
    
{
        
for (int i = 0; i < n; i++)
            scanf(
"%lf%lf"&p[i].x, &p[i].y);
        
        cnt_inter 
= 0;
        
for (int i = 0; i < n; i++)
            
for (int j = 0; j < n; j++)
            
{
                lineseg_t l1(p[i], p[(i 
+ 1% n]), l2(p[j], p[(j + 1% n]);
                point_t p;
                
if (intersection(l1, l2, p))
                    inter[cnt_inter
++= p;
            }

        sort(inter, inter 
+ cnt_inter);
        cnt_inter 
= unique(inter, inter + cnt_inter) - inter;
        
        
int e = 0;
        
for (int i = 0; i < cnt_inter; i++)
        
{
            
for (int j = 0; j < n; j++)
            
{
                lineseg_t t(p[j], p[(j 
+ 1% n]);
                
if (online(t, inter[i]) && !(t.s == inter[i]))
                    e
++;
            }

        }

        printf(
"Case %d: There are %d pieces.\n", ca++, e + 2 - cnt_inter);
    }

    
return 0;
}
posted on 2007-08-21 17:26 Felicia 閱讀(365) 評論(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>
            亚洲午夜三级在线| 亚洲一区免费在线观看| av不卡在线观看| 91久久在线| 亚洲免费电影在线观看| 午夜欧美精品| 欧美一区91| 国产情人综合久久777777| 亚洲六月丁香色婷婷综合久久| 免费日韩av| 欧美激情国产日韩| 久久er99精品| 一区二区三欧美| 亚洲一区二区三区四区五区黄 | 91久久精品国产| 国产精品久久9| 精久久久久久| 国产综合网站| 亚洲乱码一区二区| 亚洲在线观看免费| 蜜臀av性久久久久蜜臀aⅴ四虎| 久久婷婷人人澡人人喊人人爽| 欧美一激情一区二区三区| 久久久噜噜噜久久中文字幕色伊伊| 欧美在线亚洲| 日韩一二三区视频| 欧美在线视频观看| 欧美日本一道本在线视频| 国产精品永久免费在线| 在线观看欧美日韩国产| 亚洲尤物精选| 一区二区三区欧美亚洲| 一区二区三区黄色| 亚洲经典在线| 亚洲字幕一区二区| 欧美激情久久久| 国产三级精品三级| 国产精品99久久不卡二区| 免费高清在线视频一区·| 亚洲精品少妇30p| 久久看片网站| 亚洲精品中文字幕女同| 欧美一区二区三区四区在线| 欧美午夜精品久久久久久人妖| 精品成人一区| 蜜臀a∨国产成人精品| 久久国产精品第一页| 黑丝一区二区| 免费欧美在线视频| 久久亚洲综合网| 亚洲精品欧美| 99热免费精品| 国产精品午夜国产小视频| 欧美伊久线香蕉线新在线| 欧美人与性动交a欧美精品| 一本色道**综合亚洲精品蜜桃冫 | 噜噜噜久久亚洲精品国产品小说| 亚洲激情午夜| 欧美吻胸吃奶大尺度电影| 欧美一级视频| 久久精品久久99精品久久| 亚洲高清不卡在线| 亚洲欧洲精品一区二区三区| 欧美精品v国产精品v日韩精品| 亚洲欧美日韩久久精品| 久久精品夜色噜噜亚洲aⅴ| 亚洲美女啪啪| 久久免费视频一区| 亚洲欧美区自拍先锋| 欧美超级免费视 在线| 久久久精品午夜少妇| 欧美日韩免费视频| 国产精品自在欧美一区| 欧美高清不卡在线| 国产精品自在线| 亚洲图片在线| 亚洲国产视频直播| 一区二区免费在线视频| 一本色道婷婷久久欧美| 久久福利资源站| 久久精品夜色噜噜亚洲a∨| 欧美精品一区二区在线播放| 久久久中精品2020中文| 国产午夜精品久久久| 亚洲欧美在线磁力| 欧美综合激情网| 国产午夜精品美女视频明星a级| 亚洲性视频网站| 久久成人精品| 永久91嫩草亚洲精品人人| 久久久国产成人精品| 欧美电影免费观看大全| 日韩亚洲不卡在线| 欧美日韩第一区| 99精品国产福利在线观看免费 | 激情久久久久久久| 久久综合亚州| 欧美成人一区二区三区| 女仆av观看一区| 亚洲一区二区三区乱码aⅴ蜜桃女| 亚洲国产精品第一区二区三区| 亚洲午夜久久久久久久久电影院 | 国产一区二区三区视频在线观看| 欧美日韩中文另类| 国产亚洲欧美一区| 老司机亚洲精品| 欧美一区二区三区视频在线| 一区二区三区免费观看| 亚洲欧洲精品一区| 亚洲精品小视频| 亚洲精品中文字幕女同| 最新日韩在线| 亚洲精品日韩综合观看成人91| 蜜桃伊人久久| 欧美激情第8页| 欧美国产免费| 欧美成人蜜桃| 一区二区三区毛片| 欧美一级免费视频| 久久久久九九九九| 欧美国产日产韩国视频| 欧美日韩国产成人在线91| 久久免费精品日本久久中文字幕| 香蕉成人啪国产精品视频综合网| 中文国产成人精品久久一| 中日韩视频在线观看| 久久精品国产99| 欧美一区二区三区啪啪| 亚洲欧美日本精品| 久久亚洲电影| 亚洲综合首页| 男女精品视频| 亚欧美中日韩视频| 欧美日韩精品一区二区天天拍小说 | 国产精品高清一区二区三区| 国产一区999| 亚洲毛片av| 久久久国产一区二区三区| 亚洲精品日韩久久| 欧美一区二区三区久久精品茉莉花| 欧美在线二区| 国产亚洲精品一区二区| 激情懂色av一区av二区av| 久久九九国产| 国产精品日韩欧美| 午夜一级久久| 正在播放亚洲一区| 欧美日韩国产综合视频在线观看中文 | 久久综合网色—综合色88| 亚洲一区二区av电影| 国产一区在线播放| 亚洲日韩欧美一区二区在线| 欧美日韩一卡二卡| 亚洲一区亚洲| 亚洲视频观看| 国产目拍亚洲精品99久久精品| 亚洲男人影院| 香蕉精品999视频一区二区| 国产一区二区高清视频| 久久久久久久精| 欧美电影打屁股sp| 夜夜嗨av一区二区三区 | 亚洲激情国产| 亚洲人www| 国内精品模特av私拍在线观看| 欧美~级网站不卡| 欧美日韩在线视频观看| 亚洲影院在线| 久久久精品日韩欧美| 亚洲影院色无极综合| 亚洲午夜免费视频| 欧美日韩三级电影在线| 免费在线成人av| 在线日韩视频| 亚洲高清在线观看| 在线亚洲美日韩| 欧美/亚洲一区| 裸体歌舞表演一区二区| 国产精品热久久久久夜色精品三区 | 欧美日韩精品免费观看视一区二区 | 亚洲色无码播放| 久久久人成影片一区二区三区 | 红桃视频国产一区| 亚洲精品欧美激情| 久久全国免费视频| 欧美日韩在线视频首页| 欧美亚洲网站| 亚洲欧美国产精品va在线观看| 亚洲精品欧美日韩专区| 亚洲专区国产精品| 在线观看av不卡| 欧美日韩一区在线视频| 欧美在线免费观看亚洲| 亚洲美女色禁图| 久久嫩草精品久久久精品一| 日韩午夜一区| 激情综合激情| 国产精品久久久久久久午夜片| 男女精品视频| 免费视频一区二区三区在线观看|