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

我的做法是,枚舉第一個多邊形的第i條邊和第二個多邊形的第j條邊重合,然后從這條重合的邊開始,盡可能的向后擴展重合邊,然后判斷剩下的多邊形是否是凸多邊形。
比賽的時候,我在某個地方忘記對多邊形點數求模,導致wa了很久,一直到比賽結束后才AC。以此為鑒!


/*************************************************************************
Author: WHU_GCC
Created Time: 2007-10-2 12:44:17
File Name: pku3410.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 int maxn = 110;
const double eps = 1e-3;
const double pi = acos(-1.0);

typedef 
struct point_t
{
    
double x, y;
}
;

int n1, n2;
point_t p1[maxn], p2[maxn], p[maxn];

int dcmp(double x)
{
    
if (-eps < x && x  < eps)
        
return 0;
    
if (x > 0)
        
return 1;
    
return -1;
}


double dist2(const point_t &a, const point_t &b)
{
    
return (a.x - b.x) * (a.x - b.x) + (a.y - b.y) * (a.y - b.y);
}


double cross(const point_t &a, const point_t &b)
{
    
return a.x * b.y - a.y * b.x;
}


double cross(const point_t &a1, const point_t &a2, const point_t &b1, const point_t &b2)
{
    point_t a, b;
    a.x 
= a2.x - a1.x;
    a.y 
= a2.y - a1.y;
    b.x 
= b2.x - b1.x;
    b.y 
= b2.y - b1.y;
    
return cross(a, b);
}


double angle(const point_t &a, const point_t &b)
{
    
double ret = acos((a.x * b.x + a.y * b.y) / (sqrt(a.x * a.x + a.y * a.y) * sqrt(b.x * b.x + b.y * b.y)));
    
double flag = a.x * b.y - a.y * b.x;
    
if (flag > 0)
        
return ret;
    
else
        
return -ret;
}


double angle(const point_t &a1, const point_t &a2, const point_t &b1, const point_t &b2)
{
    point_t a, b;
    a.x 
= a2.x - a1.x;
    a.y 
= a2.y - a1.y;
    b.x 
= b2.x - b1.x;
    b.y 
= b2.y - b1.y;
    
return angle(a, b);
}


int main()
{
    scanf(
"%d"&n1);
    
for (int i = 0; i < n1; i++)
        scanf(
"%lf%lf"&p1[i].x, &p1[i].y);

    scanf(
"%d"&n2);
    
for (int i = 0; i < n2; i++)
        scanf(
"%lf%lf"&p2[n2 - i - 1].x, &p2[n2 - i - 1].y);

    
int flag = 0;
    
for (int i = 0; i < n1; i++)
        
for (int j = 0; j < n2; j++)
        
{
            
int k = 0;
            
while (1)
            
{
                
if (dcmp(dist2(p1[(i + k) % n1], p1[(i + k + 1% n1]) - dist2(p2[(j + k) % n2], p2[(j + k + 1% n2])) != 0)
                    
break;
                
if (k > 0)
                    
if (dcmp(angle(p1[(i + k - 1% n1], p1[(i + k) % n1], p1[(i + k) % n1], p1[(i + k + 1% n1])
                           
- angle(p2[(j + k - 1% n2], p2[(j + k) % n2], p2[(j + k) % n2], p2[(j + k + 1% n2])) != 0)
                        
break;
                k
++;
            }

            
if (k == 0)
                
continue;
            
if (angle(p1[(n1 + i - 1% n1], p1[i], p1[i], p1[(i + 1% n1])
              
+ angle(p2[(n2 + j - 1% n2], p2[j], p2[j], p2[(j + 1% n2]) > pi + eps)
                
continue;

            
if (angle(p1[(n1 + i - 1% n1], p1[i], p1[i], p1[(i + 1% n1])
              
+ angle(p2[(n2 + j - 1% n2], p2[j], p2[j], p2[(j + 1% n2]) < -eps)
                
continue;            
            
            
if (angle(p1[(i + k - 1% n1], p1[(i + k) % n1], p1[(i + k) % n1], p1[(i + k + 1% n1])
              
+ angle(p2[(j + k - 1% n2], p2[(j + k) % n2], p2[(j + k) % n2], p2[(j + k + 1% n2]) > pi + eps)
                
continue;

            
if (angle(p1[(i + k - 1% n1], p1[(i + k) % n1], p1[(i + k) % n1], p1[(i + k + 1% n1])
              
+ angle(p2[(j + k - 1% n2], p2[(j + k) % n2], p2[(j + k) % n2], p2[(j + k + 1% n2]) < -eps)
                
continue;
            
            
            
int now1 = (i + k) % n1, now2 = (now1 + 1% n1, now3 = (now2 + 1% n1;
            
int flag = 1;
            
while (now2 != i)
            
{
                
if (cross(p1[now1], p1[now2], p1[now2], p1[now3]) < 0)
                
{
                    flag 
= 0;
                    
break;
                }

                now1 
= now2;
                now2 
= now3;
                now3 
= (now3 + 1% n1;
            }

            
if (flag == 0)
                
continue;

            now1 
= (j + k) % n2, now2 = (now1 + 1% n2, now3 = (now2 + 1% n2;
            flag 
= 1;
            
while (now2 != j)
            
{
                
if (cross(p2[now1], p2[now2], p2[now2], p2[now3]) > 0)
                
{
                    flag 
= 0;
                    
break;
                }

                now1 
= now2;
                now2 
= now3;
                now3 
= (now3 + 1% n2;
            }

            
if (flag == 0)
                
continue;
            
            printf(
"1\n");
            
return 0;
        }

    printf(
"0\n");
    
return 0;
}
posted on 2007-10-02 17:52 Felicia 閱讀(640) 評論(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>
            欧美护士18xxxxhd| 一本色道久久综合狠狠躁篇怎么玩| 午夜国产欧美理论在线播放| 亚洲麻豆国产自偷在线| 日韩视频一区| 亚洲欧美日韩国产综合| 欧美一级精品大片| 久久精品99国产精品| 久久久久成人精品| 欧美成人小视频| 欧美视频日韩视频在线观看| 国产精品日韩一区二区| 韩国亚洲精品| 一本色道久久综合亚洲精品不 | 国产伦精品一区二区三区高清| 国产精品一区二区你懂得| 国内精品久久国产| 亚洲精品一区二区三区在线观看| 亚洲一区国产| 另类专区欧美制服同性| 亚洲精选在线| 久久久噜噜噜久噜久久| 欧美日韩精品免费观看| 国产一区二区视频在线观看| 日韩亚洲一区在线播放| 久久久久亚洲综合| 日韩视频一区二区在线观看| 欧美一区二区三区在线观看| 欧美激情欧美狂野欧美精品| 国产欧美精品日韩区二区麻豆天美 | 性18欧美另类| 亚洲国产精品999| 亚洲视频一二三| 欧美成人免费在线视频| 国产亚洲精品v| 亚洲一区二区免费在线| 欧美激情亚洲视频| 欧美亚洲免费在线| 欧美三区美女| 亚洲剧情一区二区| 免费亚洲一区| 午夜精品久久久久99热蜜桃导演| 欧美激情亚洲| 亚洲日韩视频| 欧美激情国产高清| 久久久久欧美精品| 狠狠色狠狠色综合人人| 欧美中文字幕视频在线观看| 一区二区三区国产在线观看| 欧美福利视频网站| 亚洲精品国久久99热| 久久亚洲综合色| 在线视频日本亚洲性| 亚洲欧美日韩区| 国产精品成人一区| 中文在线不卡| 宅男噜噜噜66一区二区66| 欧美激情一区二区三区高清视频| 亚洲国产欧美日韩| 欧美国产第二页| 模特精品在线| 日韩视频在线一区二区三区| 91久久久久| 欧美精品乱码久久久久久按摩| 精品91在线| 免费观看一区| 欧美1区3d| 一区二区三区福利| 夜色激情一区二区| 国产精品日本精品| 久久精品视频播放| 久久性色av| 亚洲国产裸拍裸体视频在线观看乱了中文| 久热成人在线视频| 欧美成熟视频| 亚洲一区免费看| 欧美一级成年大片在线观看| 黑人中文字幕一区二区三区| 美女久久网站| 欧美极品在线视频| 亚洲影院色无极综合| 亚洲欧美精品伊人久久| 极品尤物久久久av免费看| 亚洲第一精品夜夜躁人人躁| 欧美金8天国| 欧美在线视频观看| 美女性感视频久久久| 99精品国产在热久久| 亚洲欧美精品中文字幕在线| 精品动漫一区二区| 最新中文字幕一区二区三区| 国产精品成人免费| 毛片基地黄久久久久久天堂| 男人的天堂亚洲| 亚洲欧美日韩人成在线播放| 久久精品在线视频| 中文在线资源观看网站视频免费不卡| 亚洲性线免费观看视频成熟| 黑人巨大精品欧美黑白配亚洲| 亚洲人成网站999久久久综合| 国产精品国产三级国产普通话三级| 久久精品国产综合精品| 欧美黄色aa电影| 久久婷婷久久| 欧美婷婷久久| 亚洲二区在线视频| 国产欧美综合一区二区三区| 亚洲激情小视频| 狠狠色丁香婷婷综合影院| 一级日韩一区在线观看| 亚洲国内在线| 欧美一二三区精品| 亚洲欧美精品在线| 欧美诱惑福利视频| 久久久久久久精| 亚洲精品中文在线| 久久av在线| 午夜欧美大片免费观看 | 在线视频免费在线观看一区二区| 在线观看视频免费一区二区三区| 99精品视频免费全部在线| 亚洲国产精品成人精品| 欧美专区在线观看| 亚洲欧美中文日韩v在线观看| 欧美成人精品三级在线观看| 久久久久欧美精品| 国产毛片一区二区| 亚洲一区二区视频在线观看| 亚洲欧洲中文日韩久久av乱码| 欧美亚洲在线视频| 久久激情一区| 国产日韩精品一区二区| 亚洲欧美日韩第一区| 欧美一区二区日韩一区二区| 国产精品白丝黑袜喷水久久久| 亚洲国产精品毛片| 亚洲精品久久久久久久久| 美国成人毛片| 欧美激情影音先锋| 亚洲精品欧洲| 欧美日韩日韩| 中文国产成人精品| 欧美一级久久| 国产午夜精品理论片a级大结局| 亚洲一卡久久| 久久精品国产91精品亚洲| 国产午夜精品久久久久久免费视 | 午夜欧美不卡精品aaaaa| 亚洲欧美第一页| 国产精品免费看| 欧美一区二区免费| 美女视频黄a大片欧美| 亚洲激情在线激情| 欧美日韩在线播放一区| 亚洲私人影院| 久久久久久精| 亚洲人成网站色ww在线| 欧美日本精品在线| 亚洲一级二级在线| 老色鬼精品视频在线观看播放| 亚洲第一毛片| 欧美精品在线观看| 香蕉久久夜色精品国产| 欧美福利在线观看| 亚洲图片自拍偷拍| 狠狠干综合网| 欧美顶级大胆免费视频| 亚洲色图在线视频| 麻豆精品91| 亚洲素人一区二区| 国语自产精品视频在线看8查询8| 免费成人av| 亚洲在线成人精品| 欧美国产亚洲精品久久久8v| 亚洲视频一区二区| 黄色影院成人| 国产精品国产一区二区| 久久久99久久精品女同性 | 久久中文在线| 一区二区三区高清| 艳妇臀荡乳欲伦亚洲一区| 亚洲一区二区三区午夜| 美日韩丰满少妇在线观看| 一区二区三区四区五区视频| 国产综合在线看| 欧美日韩精品欧美日韩精品 | 欧美激情小视频| 欧美专区一区二区三区| 在线亚洲免费| 欧美jizzhd精品欧美巨大免费| 亚洲欧美日韩国产中文| 91久久久久久国产精品| 国产亚洲人成a一在线v站| 欧美日韩xxxxx| 久久久蜜桃一区二区人| 午夜精品久久久久久久久久久久久 | 亚洲免费网站| 一区二区三区成人| 亚洲精品一区二区三区蜜桃久| 国语精品中文字幕|