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

我的做法是,枚舉第一個多邊形的第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 閱讀(641) 評論(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>
            亚洲第一色中文字幕| 欧美人与性动交cc0o| aⅴ色国产欧美| 久久九九久精品国产免费直播| 一本色道久久综合精品竹菊 | 亚洲精品视频二区| 狠狠色噜噜狠狠狠狠色吗综合| 99视频在线精品国自产拍免费观看| 国内精品久久国产| 亚洲影院在线观看| 中文在线不卡| 欧美激情一级片一区二区| 玖玖视频精品| 国产在线精品自拍| 亚洲调教视频在线观看| 亚洲一区二区三区中文字幕在线| 欧美激情精品久久久久久免费印度 | 久久中文字幕一区| 国产伦精品一区二区三区免费迷| 在线一区观看| 亚洲一区二区精品在线| 欧美日韩国产影片| 亚洲精品视频免费观看| 夜夜嗨av色一区二区不卡| 欧美精品www| 亚洲老板91色精品久久| 中文在线不卡| 国产精品久久久久久久久动漫| 日韩亚洲欧美成人| 亚洲香蕉伊综合在人在线视看| 欧美日韩另类在线| 在线亚洲精品| 欧美在线影院| 加勒比av一区二区| 久久综合一区二区三区| 亚洲国产精品成人一区二区| 亚洲国产一二三| 欧美福利视频在线| 日韩视频久久| 亚欧成人在线| 韩日在线一区| 欧美激情精品久久久久久蜜臀| 亚洲欧洲在线一区| 亚洲一区综合| 国内伊人久久久久久网站视频 | 午夜在线播放视频欧美| 久久久一本精品99久久精品66| 影音先锋久久| 欧美日韩国产在线观看| 亚洲小少妇裸体bbw| 美女性感视频久久久| 麻豆freexxxx性91精品| 亚洲一区二区在线免费观看视频| 亚洲综合精品| 国产一区二区三区免费观看| 久久久久久亚洲精品杨幂换脸| 欧美激情一二区| 亚洲尤物视频在线| 影音先锋另类| 欧美日韩免费高清| 欧美一区二区三区四区高清| 欧美成人激情在线| 亚洲欧美日韩国产成人精品影院 | 欧美成人有码| 亚洲一区欧美一区| 亚洲大片在线| 欧美一区二区三区视频在线| 在线观看av一区| 国产精品国产| 欧美成人精品一区| 午夜视频一区在线观看| 亚洲日本成人网| 久久精品一区二区三区不卡牛牛| 亚洲观看高清完整版在线观看| 国产精品久久久久77777| 久热精品在线视频| 亚洲欧洲av一区二区| 亚洲三级观看| 欧美成人亚洲| 久久久.com| 亚洲女优在线| 妖精成人www高清在线观看| 黄色一区二区三区四区| 国产精品久久久久天堂| 欧美好吊妞视频| 久色婷婷小香蕉久久| 午夜视频久久久久久| 夜夜嗨av一区二区三区网页| 欧美成人性网| 另类天堂视频在线观看| 欧美一区二区三区四区高清 | 欧美粗暴jizz性欧美20| 欧美一级视频精品观看| 亚洲小说欧美另类社区| 亚洲欧洲精品一区二区三区| 狠狠色丁香婷综合久久| 国产女主播在线一区二区| 欧美日韩亚洲一区二区三区在线观看 | 久久综合一区二区| 欧美中文字幕久久| 亚久久调教视频| 亚洲欧美日本国产有色| 亚洲视频导航| 亚洲夜间福利| 亚洲在线一区| 亚洲欧美色一区| 亚洲女人天堂av| 亚洲影院一区| 亚洲综合精品四区| 午夜精品区一区二区三| 性久久久久久久| 香蕉久久a毛片| 欧美在线观看一区二区三区| 欧美一区二区三区视频免费播放 | 狠狠狠色丁香婷婷综合激情| 国产专区精品视频| 在线日韩中文字幕| 亚洲国产日韩精品| 亚洲美女啪啪| 一区二区三区视频在线| 亚洲一区二区三区四区五区午夜 | 久久久久久亚洲综合影院红桃| 久久久美女艺术照精彩视频福利播放 | 亚洲欧美国产精品va在线观看| 午夜精品久久久久99热蜜桃导演| 午夜亚洲性色福利视频| 久久精品国产69国产精品亚洲| 久久久久久夜精品精品免费| 免费欧美网站| 欧美日韩美女在线| 国产精品爽黄69| 国产专区综合网| 亚洲欧洲在线免费| 亚洲午夜三级在线| 欧美在线视频a| 免费成人美女女| 亚洲欧洲精品一区二区三区波多野1战4 | 欧美一区二区三区在线| 免费观看亚洲视频大全| 欧美日韩直播| 狠狠色噜噜狠狠色综合久| 99精品久久| 久久精品人人做人人爽| 亚洲国产成人高清精品| 亚洲图片欧美日产| 乱码第一页成人| 国产精品国产| 91久久精品一区| 欧美亚洲日本国产| 亚洲国产成人av| 亚洲一区三区电影在线观看| 老司机久久99久久精品播放免费| 欧美午夜电影在线观看| 在线观看欧美视频| 亚洲欧美日韩精品久久| 欧美激情1区2区3区| 亚洲欧美色婷婷| 欧美另类一区二区三区| 激情另类综合| 香蕉成人啪国产精品视频综合网| 亚洲成色www8888| 欧美在线高清视频| 欧美体内she精视频| 91久久精品一区二区别| 久久精品91久久久久久再现| 亚洲三级免费观看| 久久亚洲春色中文字幕久久久| 国产精品麻豆va在线播放| 亚洲精选成人| 蜜臀久久99精品久久久久久9| 亚洲午夜激情免费视频| 欧美激情一区二区三区在线| 樱桃国产成人精品视频| 欧美在线高清视频| 亚洲午夜视频| 欧美日韩国产999| 亚洲精品国产精品国自产观看| 久久精品综合| 亚洲欧美日韩网| 国产精品久久久久久久7电影| 日韩系列在线| 亚洲黄色三级| 欧美成年人网站| 亚洲国产精品久久久| 免费日韩精品中文字幕视频在线| 午夜在线视频观看日韩17c| 国产精品丝袜91| 午夜国产精品视频免费体验区| 99国产一区二区三精品乱码| 欧美日韩成人在线播放| 999亚洲国产精| 亚洲国产日本| 欧美精品亚洲二区| 亚洲乱码精品一二三四区日韩在线| 欧美激情第9页| 亚洲女女做受ⅹxx高潮| 一本到12不卡视频在线dvd| 欧美日韩国产系列| 乱人伦精品视频在线观看| 亚洲欧美日韩一区|