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

糯米

TI DaVinci, gstreamer, ffmpeg
隨筆 - 167, 文章 - 0, 評論 - 47, 引用 - 0
數據加載中……

POJ 2187 Beauty Contest 凸包直徑

題目大意:
給一堆點,求直線距離最遠的兩個點。

思路:
就是求“凸多邊形的直徑”。google一下,很多結果的啦。
首先要求出凸包,然后用一個比較牛逼的算法貌似可以在O(N)時間內求出凸包直徑。
但是那算法太復雜啦,看了半天都看不懂,所以就枚舉凸包每兩個點之間的距離了。
還是能200+ms過,因為凸包求出來以后,N就大大減小了。

#include <stdio.h>
#include 
<stdlib.h>

struct point {
    
short x, y;
}
;
struct point points[50024], *convex[50024];
int points_cnt, convex_cnt;

__inline 
void swap(struct point *a, struct point *b)
{
    
struct point t = *a;
    
*= *b;
    
*= t;
}


__inline 
int cmp(struct point *p1, struct point *p2)
{
    
int a, b, c, d, r;
    
    a 
= p1->- points[0].y;
    b 
= p1->- points[0].x;
    c 
= p2->- points[0].y;
    d 
= p2->- points[0].x;
    r 
= a*- b*c;
    
if (!r) {
        
if (b)
            
return b - d;
        
return a - c;
    }

    
return r;
}


__inline 
int turn_left(struct point *p1, struct point *p2, struct point *p3)
{
    
return    (int)p1->x*p2->- (int)p1->x*p3->- (int)p2->x*p1->+ 
            (
int)p3->x*p1->+ (int)p2->x*p3->- (int)p3->x*p2->y
            
>= 0;
}


void qs(struct point *arr, int len)
{
    
int l, r, p;
    
    
if (len < 2)
        
return ;

    l 
= 0;
    p 
= len - 1;
    r 
= len - 2;
    
while (1{
        
while (l < p && cmp(&arr[l], &arr[p]) < 0)
            l
++;
        
while (r >= 0 && cmp(&arr[r], &arr[p]) >= 0)
            r
--;
        
if (l > r)
            
break;
        swap(
&arr[l], &arr[r]);
    }

    swap(
&arr[l], &arr[p]);

    qs(arr, l);
    qs(arr 
+ l + 1, len - l - 1);
}


int main()
{
    
int i, j, x, y, left, down, min_idx, max_val, val;

    freopen(
"e:\\test\\in.txt""r", stdin);

    scanf(
"%d"&points_cnt);
    left 
= down = 0x7fffffff;
    
for (i = 0; i < points_cnt; i++{
        scanf(
"%d%d"&x, &y);
        points[i].x 
= x;
        points[i].y 
= y;
        
if (x < left || (x == left) && y < down) {
            left 
= x;
            down 
= y;
            min_idx 
= i;
        }

    }

    swap(
&points[0], &points[min_idx]);
    qs(points 
+ 1, points_cnt - 1);

    convex_cnt 
= 0;
    convex[convex_cnt
++= &points[0];
    convex[convex_cnt
++= &points[1];
    
for (i = 2; i < points_cnt; i++{
        
while (convex_cnt >= 2 && 
               
!turn_left(convex[convex_cnt - 2], 
                         convex[convex_cnt 
- 1],
                         
&points[i]))
        
{
              convex_cnt
--;
        }

        convex[convex_cnt
++= &points[i];
    }


    max_val 
= 0;
    
for (i = 0; i < convex_cnt - 1; i++{
        
for (j = i + 1; j < convex_cnt; j++{
            x 
= convex[i]->- convex[j]->x;
            y 
= convex[i]->- convex[j]->y;
            val 
= x*+ y*y;
            
if (val > max_val)
                max_val 
= val;
        }

    }

    printf(
"%d\n", max_val);

    
return 0;
}

posted on 2010-02-16 14:05 糯米 閱讀(456) 評論(0)  編輯 收藏 引用 所屬分類: POJ

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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| 翔田千里一区二区| 久久永久免费| 欧美性感一类影片在线播放| 国产亚洲一区精品| 亚洲激情在线观看| 亚洲欧美日韩国产一区二区三区| 性欧美xxxx大乳国产app| 久久久一区二区| 91久久久久久国产精品| 亚洲一级特黄| 久久视频精品在线| 欧美日韩在线一区| 精品二区久久| 亚洲在线播放| 欧美va天堂在线| 一区二区三区久久| 久热国产精品视频| 国产精品欧美经典| 亚洲人成在线观看一区二区| 午夜精品一区二区三区在线视 | 亚洲欧美日韩爽爽影院| 久久亚洲高清| 日韩亚洲一区在线播放| 欧美一区二区三区播放老司机| 欧美激情偷拍| 国产亚洲在线| 亚洲在线观看视频网站| 欧美激情影院| 欧美综合二区| 国产精品入口福利| 一区二区久久| 亚洲丰满在线| 久久久久久久久久码影片| 国产精品久久久久久久久| 亚洲精品久久久久久久久久久| 久久久久综合网| 一区二区三区.www| 欧美精品久久天天躁| 亚洲第一在线综合在线| 久久久久亚洲综合| 西西裸体人体做爰大胆久久久| 欧美色网在线| 一本大道久久a久久精二百| 亚洲国产一区在线观看| 香蕉成人伊视频在线观看| 亚洲毛片在线| 欧美日韩国产精品一区| 亚洲欧洲久久| 欧美激情一级片一区二区| 久久成人免费网| 国产综合色在线| 久久狠狠亚洲综合| 亚洲欧美日韩在线播放| 国产精品美女久久久浪潮软件| 中文精品视频| 一本大道久久a久久精品综合| 欧美日韩不卡| 在线亚洲欧美| 亚洲一区二区三区在线观看视频| 国产精品v片在线观看不卡| 亚洲一区二区在线免费观看视频| 99在线热播精品免费99热| 欧美日韩ab片| 一区二区欧美视频| 亚洲视频一二区| 国产情侣久久| 亚洲永久免费| 久久激情中文| 欧美亚洲在线| 国产一区二区中文字幕免费看| 欧美在线播放一区| 欧美在线播放一区| 亚洲第一二三四五区| 亚洲国产一区二区在线| 欧美日韩精品免费| 亚洲欧美日韩区| 欧美一区二区三区喷汁尤物| 一区二区三区自拍| 亚洲国产精品成人久久综合一区| 欧美日本高清| 欧美在线关看| 玖玖视频精品| 亚洲新中文字幕| 欧美中文字幕在线| 亚洲每日更新| 亚洲自拍偷拍网址| 亚洲电影视频在线| 夜夜嗨av色综合久久久综合网| 国产欧美日韩精品a在线观看| 久久伊人亚洲| 欧美午夜国产| 欧美国产丝袜视频| 国产精品成人免费视频| 麻豆91精品| 国产精品超碰97尤物18| 老司机精品视频一区二区三区| 欧美精品一区二区视频| 久久精品日韩欧美| 欧美日韩国产bt| 久久综合五月| 国产精品美女久久福利网站| 欧美国产一区二区在线观看| 国产女主播一区二区| 亚洲欧洲日本一区二区三区| 国产亚洲成av人在线观看导航| 亚洲视频每日更新| 欧美与黑人午夜性猛交久久久| 亚洲婷婷国产精品电影人久久| 麻豆av一区二区三区久久| 久久精品99| 国产精品一区二区黑丝| 日韩视频在线一区二区| 亚洲国产欧美一区二区三区同亚洲 | 亚洲私人影吧| 亚洲精品免费网站| 久久久精品视频成人| 亚洲一级特黄| 欧美另类变人与禽xxxxx| 欧美高清视频在线| 影音先锋亚洲精品| 亚洲欧美日韩电影| 亚洲免费网站| 欧美日韩国语| 日韩一区二区精品| 99国产精品久久久久老师| 久久综合狠狠综合久久激情| 久久久久免费视频| 国产日韩精品视频一区二区三区| 一区二区免费在线播放| 亚洲一区二区毛片| 欧美日韩视频专区在线播放| 亚洲乱码国产乱码精品精天堂 | 欧美在线看片a免费观看| 欧美亚洲一区二区在线观看| 国产精品欧美一区二区三区奶水| 在线亚洲精品福利网址导航| 午夜精品久久久久久久99水蜜桃| 国产精品久久久久久妇女6080| 一区二区免费在线视频| 亚洲综合日韩| 国产免费成人av| 久久久国产精彩视频美女艺术照福利 | 国产中文一区二区| 久久国产直播| 免费观看成人网| 最新国产拍偷乱拍精品 | 亚洲一区二区三区中文字幕| 亚洲欧美日韩一区二区在线 | 亚洲一区二区三区在线| 国产精品麻豆成人av电影艾秋| 亚洲在线日韩| 久久综合久久综合这里只有精品 | 国产精品国产三级国产普通话三级| 一区二区激情视频| 宅男噜噜噜66一区二区| 国产精品美女| 欧美激情一区二区三区四区| 一道本一区二区| 国产亚洲二区| 91久久国产精品91久久性色| 欧美福利精品| 亚洲尤物视频网| 欧美阿v一级看视频| 一区二区三区欧美在线观看| 国产日本欧美一区二区三区在线 | 亚洲免费中文字幕| 精品福利av| 国产精品成人一区二区网站软件| 午夜精品久久久久| 欧美成人综合| 午夜精品99久久免费| 1769国产精品| 国产精品入口尤物| 欧美成人一区二区| 午夜国产精品视频| 亚洲欧洲精品一区二区三区不卡| 欧美一级网站| aaa亚洲精品一二三区| 国产视频亚洲精品| 欧美激情亚洲自拍| 久久久久免费观看| 一区二区三区日韩精品视频| 欧美黄色aa电影| 久久久蜜臀国产一区二区| 在线亚洲精品| 亚洲精品视频一区| 永久免费精品影视网站| 国产老女人精品毛片久久| 欧美日韩精品一区视频| 狂野欧美激情性xxxx欧美|