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

pku 1228 Grandpa's Estate 凸多邊形的唯一性(凸包)

題意:
一個(gè)凸多邊形的邊界上有若干木樁,現(xiàn)丟失部分木樁,問(wèn)由剩下的木樁能否唯一確定這個(gè)多邊形

解法:
首先能夠唯一確定的條件是由剩下的木樁確定的凸包的每條邊上至少包含3個(gè)木樁,這個(gè)自己畫圖比劃下就知道了- -
然后就是求一個(gè)凸包了。在這種坐標(biāo)都是整數(shù)的情況下,凸包最好不要用atan2函數(shù),而是用叉積來(lái)比較。我特地用純C寫了個(gè),有要的童鞋可以拿去當(dāng)模板
有個(gè)陰險(xiǎn)的地方,就是測(cè)試數(shù)據(jù)只有3個(gè)點(diǎn),而且3點(diǎn)一線。。。你懂的

代碼
 1#  include <stdio.h>
 2#  include <stdlib.h>
 3# define N 1200
 4# define cross(x1,y1,x2,y2) ((x1)*(y2)-(x2)*(y1))
 5# define min(a,b) ((a)<(b)?(a):(b))
 6# define max(a,b) ((a)>(b)?(a):(b))
 7typedef struct
 8{
 9    int x,y;
10}
point;
11int n,c;
12point data[N],ans[N],std;
13int dis(point *pos)
14{
15    return (pos->x-std.x)*(pos->x-std.x)+(pos->y-std.y)*(pos->y-std.y);
16}

17int isin(point *a,point *b,point *pos)
18{
19    if(pos->x>max(a->x,b->x)||pos->x<min(a->x,b->x)||pos->y>max(a->y,b->y)||pos->y<min(a->y,b->y)) return 0;
20    else if(cross(pos->x-a->x,pos->y-a->y,b->x-a->x,b->y-a->y)!=0return 0;
21    else return 1;
22}

23int cmp(const void *a,const void *b)
24{
25    point *aa=(point *)a,*bb=(point *)b;
26    if(cross(bb->x-std.x,bb->y-std.y,aa->x-std.x,aa->y-std.y))
27            return cross(bb->x-std.x,bb->y-std.y,aa->x-std.x,aa->y-std.y);
28    else 
29            return dis(aa)-dis(bb);
30}

31void sort()
32{
33    int i;
34    int x=0xfffffff,y=0xfffffff;
35    for(i=0;i<n;i++)
36        if(data[i].y<y||data[i].y==y&&data[i].x<x)
37            y=data[i].y,x=data[i].x;
38    std.x=x;
39    std.y=y;
40    qsort(data,n,sizeof(point),cmp);
41}

42void build()
43{
44    int i;
45    c=0;
46    sort();
47    for(i=0;i<n;i++)
48    {
49        while(c>=2&&cross(data[i].x-ans[c-1].x,data[i].y-ans[c-1].y,ans[c-1].x-ans[c-2].x,ans[c-1].y-ans[c-2].y)>=0) c--;
50        ans[c++]=data[i];
51    }

52    if(c>0) ans[c++]=ans[0];
53}

54int chk()
55{
56    int i;
57    for(i=0;i<c-1;i++)
58    {
59        int count=0,j;
60        for(j=0;j<n;j++)
61            if(isin(&ans[i],&ans[i+1],&data[j]))
62                count++;
63        if(count<3return 0;
64    }

65    return 1;
66}

67int main()
68{
69    int test;
70    scanf("%d",&test);
71    while(test--)
72    {
73        int i;
74        scanf("%d",&n);
75        for(i=0;i<n;i++)
76            scanf("%d %d",&data[i].x,&data[i].y);
77        build();
78        if(c>3&&chk()) printf("YES\n");
79        else printf("NO\n");
80    }

81    return 0;
82}

83

posted on 2011-01-15 02:27 yzhw 閱讀(300) 評(píng)論(0)  編輯 收藏 引用 所屬分類: geometry&phycise

<2015年2月>
25262728293031
1234567
891011121314
15161718192021
22232425262728
1234567

導(dǎo)航

統(tǒng)計(jì)

公告

統(tǒng)計(jì)系統(tǒng)

留言簿(1)

隨筆分類(227)

文章分類(2)

OJ

最新隨筆

搜索

積分與排名

最新評(píng)論

閱讀排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲精品美女91| 伊人成综合网伊人222| 亚洲视频播放| 亚洲精品自在久久| 99国产精品久久久久久久成人热| 亚洲欧洲中文日韩久久av乱码| 欧美激情一区二区三区高清视频| 免费成人性网站| 欧美国产日韩在线观看| 亚洲国产欧美在线| 在线视频欧美日韩精品| 亚洲欧美一区二区精品久久久| 亚洲欧美日韩视频一区| 久久久久一区二区三区| 欧美激情成人在线| 国产精品欧美风情| 玉米视频成人免费看| 日韩网站在线观看| 欧美一区二区高清| 欧美11—12娇小xxxx| 日韩一区二区免费看| 久久精品国产亚洲精品| 欧美激情一区二区三区高清视频| 国产精品v片在线观看不卡| 国产视频在线一区二区| 日韩图片一区| 欧美主播一区二区三区美女 久久精品人| 欧美一区二区三区精品电影| 免费影视亚洲| 一区二区高清| 久久综合色综合88| 亚洲永久精品大片| 国产一区二区三区久久久| 亚洲国产三级网| 欧美一区在线视频| 亚洲国产一区二区a毛片| 一区二区三区 在线观看视| 久久亚洲春色中文字幕久久久| 国产精品成人v| 亚洲国产美国国产综合一区二区| 性亚洲最疯狂xxxx高清| 亚洲精品一区二区在线观看| 久久国产主播| 国产精品久久久一本精品| 亚洲国产小视频在线观看| 久久aⅴ国产紧身牛仔裤| 日韩一级大片在线| 免费久久精品视频| 国产一区导航| 欧美亚洲免费| 制服丝袜激情欧洲亚洲| 欧美日韩国产区一| 亚洲片在线观看| 蜜桃av综合| 国产精品jizz在线观看美国| 国产精品国产三级国产aⅴ入口 | 欧美激情一区二区三区蜜桃视频 | 国产精品福利av| 亚洲美女av网站| 欧美国产综合一区二区| 久久久国产精品亚洲一区 | 在线视频欧美一区| 欧美视频一区二区三区在线观看| 日韩一区二区免费高清| 亚洲经典在线看| 欧美日本视频在线| 一区二区精品国产| 中文欧美字幕免费| 国产精品亚洲综合久久| 欧美一区二区三区另类| 欧美伊人影院| 亚洲盗摄视频| 亚洲美女少妇无套啪啪呻吟| 欧美日韩国产精品专区| 一区二区三区四区蜜桃| 中日韩高清电影网| 国产精品永久免费在线| 久久久www成人免费毛片麻豆| 新67194成人永久网站| 国产一区二区三区四区hd| 久久最新视频| 欧美激情成人在线| 香港成人在线视频| 久久精品综合一区| 亚洲精品永久免费| 99在线热播精品免费99热| 国产精品私房写真福利视频| 久久久国产成人精品| 久久午夜色播影院免费高清| 亚洲免费成人av| 亚洲一区二区三区色| 激情久久五月天| 亚洲激情亚洲| 国产一级久久| 91久久午夜| 国产一区二区久久久| 亚洲国产成人av好男人在线观看| 欧美韩日视频| 欧美一级艳片视频免费观看| 麻豆久久久9性大片| 亚洲影视综合| 老鸭窝毛片一区二区三区| 亚洲香蕉在线观看| 久久精品视频播放| 亚洲一本视频| 两个人的视频www国产精品| 亚洲激情啪啪| 国产精品大全| 欧美gay视频激情| 国产精品视频午夜| 亚洲成色精品| 国产精品一区2区| 亚洲黄色免费| 国内精品福利| 中国成人黄色视屏| 亚洲免费观看高清完整版在线观看| 亚洲一区二区三区乱码aⅴ蜜桃女 亚洲一区二区三区乱码aⅴ | 99亚洲视频| 久久精品在线视频| 欧美在线91| 欧美视频三区在线播放| 亚洲激情一区| 亚洲激情校园春色| 久久免费精品视频| 久久―日本道色综合久久| 国产精品久久午夜| 亚洲美女福利视频网站| 亚洲精品视频二区| 久久―日本道色综合久久| 久久精品国产99国产精品| 欧美偷拍另类| 99国产精品久久久| 在线亚洲激情| 欧美剧在线免费观看网站| 欧美激情在线观看| 午夜一区二区三区在线观看| 亚洲少妇最新在线视频| 欧美成人在线免费视频| 亚洲福利视频专区| 日韩视频在线一区二区三区| 欧美高清在线观看| 亚洲精品你懂的| 一本一道久久综合狠狠老精东影业| 蜜桃久久精品乱码一区二区| 欧美电影免费观看| 亚洲区在线播放| 欧美激情综合在线| 亚洲裸体俱乐部裸体舞表演av| 一本久久精品一区二区| 欧美视频在线免费| 亚洲一区二区黄色| 久久精品视频在线| 在线看片日韩| 欧美国产丝袜视频| 一本色道久久综合亚洲精品小说 | 欧美成人一区二区三区在线观看| 欧美aⅴ99久久黑人专区| 在线观看一区二区视频| 欧美精品福利在线| 亚洲图片激情小说| 久久精品成人欧美大片古装| 国产亚洲视频在线| 乱码第一页成人| 99精品视频免费| 性视频1819p久久| 一区二区三区无毛| 欧美日本中文| 在线观看的日韩av| 亚洲色诱最新| 亚洲欧美日韩国产| 久久本道综合色狠狠五月| 欧美激情国产日韩| 欧美亚洲一区在线| 欧美成人乱码一区二区三区| 国产精品一区二区三区观看| 91久久久亚洲精品| 欧美91精品| 蘑菇福利视频一区播放| 亚洲国产精品成人综合| 亚洲国产综合视频在线观看| 亚洲综合精品一区二区| 一区二区三区日韩| 欧美一区永久视频免费观看| 亚洲国产精品成人久久综合一区| 欧美日本在线视频| 久久av红桃一区二区小说| 亚洲免费观看视频| 欧美14一18处毛片| 午夜日韩视频| 亚洲精品一二区| 国产日韩欧美亚洲一区| 欧美激情一区| 久久综合九色九九| 午夜影视日本亚洲欧洲精品| 亚洲免费成人| 亚洲福利国产| 久久亚洲综合色一区二区三区| 亚洲欧美日韩一区二区三区在线观看 | 亚洲小视频在线观看| 在线观看国产成人av片|