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

隨筆 - 87  文章 - 279  trackbacks - 0
<2007年6月>
272829303112
3456789
10111213141516
17181920212223
24252627282930
1234567

潛心看書研究!

常用鏈接

留言簿(19)

隨筆分類(81)

文章分類(89)

相冊

ACM OJ

My friends

搜索

  •  

積分與排名

  • 積分 - 221556
  • 排名 - 118

最新評論

閱讀排行榜

評論排行榜

用差積做極角排序,減少浮點誤差

#include? < iostream >
#include?
< algorithm >
using ? namespace ?std;

typedef?
int ?XYType;

struct ?POINT? {
????XYType?x,?y;
}
?ps;

XYType?cross(POINT?p1,?POINT?p2,?POINT?p0)?
{
????
// 求矢量[p0,p1],[p0,p2]的差積;
???? return ?(p1.x? - ?p0.x)? * ?(p2.y? - ?p0.y)? - ?(p2.x? - ?p0.x)? * ?(p1.y? - ?p0.y);
}


int ?cmp(POINT?p1,?POINT?p2)? {
????
// 以ps為中心的極角排序
????XYType?ax,?ay,?bx,?by;
????ax?
= ?p1.x? - ?ps.x;?ay? = ?p1.y? - ?ps.y;
????bx?
= ?p2.x? - ?ps.x;?by? = ?p2.y? - ?ps.y;
????
if ?(ay? * ?by? <= ? 0 )? return ?by? > ?ay? || ?(by? == ?ay? && ?bx? > ?ax);
????XYType?ret?
= ?cross(p1,?p2,?ps);
????
if ?(ret? > ? 0 )? return ? 1 ;
????
if ?(ret? == ? 0 )? return ?bx? > ?ax;
????
if ?(ret? < ? 0 )? return ? 0 ;
????
return ? 1 ;
}
;

int ?main()? {
????freopen(
" test.txt " ,? " r " ,?stdin);
????POINT?arrP[
100 ];
????
int ?n? = ? 0 ,?i,?beg;
????
int ?stack[ 100 ],?top;????
????
while ?(scanf( " %d%d " ,? & arrP[n].x,? & arrP[n].y)? != ?EOF)?n ++ ;
????
for ?(i = 1 ;?i < n;?i ++ )? {
????????
if ?(arrP[i].y? < ?arrP[ 0 ].y? || ?(arrP[i].y? == ?arrP[ 0 ].y? && ?arrP[i].x? < ?arrP[ 0 ].x))?
????????????swap(arrP[
0 ],?arrP[i]);
????}

????ps.x?
= ?arrP[ 0 ].x;?ps.y? = ?arrP[ 0 ].y;
????sort(arrP
+ 1 ,?arrP + n,?cmp);
????
for ?(i = 0 ;?i <= 2 ;?i ++ )?stack[i]? = ?i;
????top?
= ? 2 ;
????
for ?(i = 3 ;?i < n;?i ++ )? {
????????
while ?(cross(arrP[stack[top]],?arrP[i],?arrP[stack[top - 1 ]])? < ? 0 )? {
????????????top
-- ;
????????}

????????stack[
++ top]? = ?i;
????}

????
for ?(i = 0 ;?i <= top;?i ++ )? {
????????
if ?(arrP[stack[i]].x? == ? 0 ? && ?arrP[stack[i]].y? == ? 0 )? {
????????????beg?
= ?i;
????????????
break ;
????????}

????????
// printf("(%d,%d)\n",?arrP[stack[i]].x,?arrP[stack[i]].y);
????}

????
for ?(i = beg;?i <= top + beg;?i ++ )? {
????????
int ?k? = ?i? > ?top? ? ?i? - ?top? - ? 1 ?:?i;
????????printf(
" (%d,%d)\n " ,?arrP[stack[k]].x,?arrP[stack[k]].y);
????}

????
return ? 0 ;
}
posted on 2007-03-25 02:43 閱讀(1208) 評論(1)  編輯 收藏 引用 所屬分類: 數據結構與算法

FeedBack:
# re: 凸包... 2007-06-30 10:26 姜雨生
#include<fstream>
#include<cstdlib>
using namespace std;
ifstream fin ("bag.in");
ofstream fout ("bag.out");
struct xys
{
int x;
int y;
};
int N;//數目
xys xy[101];//坐標系
int top;//堆棧頂
int stk[101];//堆棧
void swap(xys *a,xys *b)
{
xys tmp = *a;
*a = *b;
*b =tmp;
}
int multi(xys a,xys b,xys c)
{
return (a.x-c.x)*(b.y-c.y)-(b.x-c.x)*(a.y-c.y);//求叉積
}
bool comp(xys p1,xys p2)
{
int t;
t=multi(p1,p2,xy[0]);
if ((t>=0)&&((p1.x-xy[0].x)+(p1.y-xy[0].y)<(p2.x-xy[0].x)+(p2.y-xy[0].y)))
return true;//叉積正確
return false;
}
void sort(int p,int r)
{
int i,j;
xys x;
if (r-p+1<=5)
{
for (j=p+1;j<=r;j++)
{
i=j;
while(i>1&&comp(xy[i],xy[i-1]))
{
swap(&xy[i],&xy[i-1]);//交換元素
i--;
}
}
}
else
{
x=xy[p+rand()%(r-p+1)];//隨即選區一個支點
i=p,j=r;
do
{
while (comp(xy[i],x))i++;
while (comp(x,xy[j]))j--;
if (i<j)swap(&xy[i],&xy[j]);
}//一次規劃
while (i<j);
sort(p,j);//前半部
sort(p+1,r);//后半部
}
}
void init()
{
int i;
fin>>N;
for(i=0;i<N;i++){
fin>>xy[i].x>>xy[i].y;
if (xy[i].y<=xy[0].y&&xy[i].x<xy[0].y) swap(xy[0],xy[i]);//交換
}
sort(1,N-1);
}
void graham()
{
int i;
for(i=1;i<=3;i++) stk[i]=i-1;
top=3;
for(i=3;i<N;i++)
{
while(multi(xy[i],xy[stk[top]],xy[stk[top-1]])>=0) top--;//所有未向左傳的點去掉
top++;
stk[top]=i;//入棧
}
for (i=1;i<=top;i++)
fout<<xy[stk[i]].x<<" "<<xy[stk[i]].y<<endl;
}
int main (void)
{
init();
graham();//掃描出凸包,打印
return 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| 亚洲视频 欧洲视频| 国产精品久久夜| 久久精品国产一区二区三区| 欧美制服丝袜| 亚洲第一黄网| 亚洲国产日韩一区二区| 欧美日韩国产精品一区二区亚洲| 一本一本久久a久久精品综合麻豆 一本一本久久a久久精品牛牛影视 | 欧美成人第一页| 欧美成人综合一区| 亚洲一区二区三区中文字幕| 一区二区三区日韩精品| 国产九九视频一区二区三区| 欧美精品久久99久久在免费线| 亚洲精品综合精品自拍| 夜夜嗨av一区二区三区| 国产精品午夜久久| 麻豆成人综合网| 欧美日韩一区二区在线播放| 欧美在线视频a| 欧美91福利在线观看| 亚洲性视频网址| 久久久久久久久久码影片| 亚洲日本欧美| 香蕉久久一区二区不卡无毒影院| 一区在线电影| 中文有码久久| 亚洲三级毛片| 香蕉免费一区二区三区在线观看| 亚洲精品一二三| 欧美中文字幕第一页| 99在线精品视频在线观看| 欧美一区二区| 亚洲一区二区三区在线播放| 久久久久久久综合日本| 亚洲自拍偷拍麻豆| 女同一区二区| 鲁大师影院一区二区三区| 国产精品久久久久毛片软件 | 亚洲黑丝在线| 欧美一区二区三区四区在线观看地址 | 久久久久久久尹人综合网亚洲| 中文在线不卡视频| 免费欧美视频| 美女诱惑一区| 国产一区在线视频| 亚洲综合国产激情另类一区| 艳女tv在线观看国产一区| 久久久久久电影| 久久精品2019中文字幕| 国产精品久久久久久亚洲调教| 亚洲激情婷婷| 亚洲黄色在线看| 久久人人看视频| 久久久亚洲国产天美传媒修理工 | 欧美日韩国产天堂| 亚洲第一在线| 亚洲国产裸拍裸体视频在线观看乱了中文| 午夜精品成人在线| 亚洲免费在线| 国产精品男gay被猛男狂揉视频| 亚洲免费观看高清完整版在线观看熊 | 亚洲高清久久网| 久久综合中文色婷婷| 久久综合福利| 亚洲国产成人午夜在线一区| 久久精品亚洲一区二区三区浴池| 久久久999国产| 激情视频一区二区| 久久久人成影片一区二区三区观看 | 国产精品青草久久| 亚洲一区免费看| 欧美在线网站| 好看的日韩视频| 奶水喷射视频一区| 亚洲精品女人| aa级大片欧美三级| 欧美色欧美亚洲高清在线视频| 日韩午夜高潮| 亚洲一区在线视频| 国产欧美欧美| 久久久久久夜| 亚洲日本免费电影| 午夜精品福利电影| 国产一区二区三区黄| 久久手机精品视频| 亚洲精选久久| 欧美一区二区三区在线播放| 黄色成人av在线| 欧美精品一区二区蜜臀亚洲| 亚洲神马久久| 免费成年人欧美视频| 日韩一级大片在线| 国产热re99久久6国产精品| 久久久久久久久综合| 亚洲高清在线播放| 亚洲欧美日韩在线一区| 国产一区二区0| 女人色偷偷aa久久天堂| 99天天综合性| 另类激情亚洲| 亚洲一区二区欧美日韩| 国产一区二区成人| 欧美巨乳在线观看| 欧美一区二区三区电影在线观看| 亚洲国产高清自拍| 欧美在线综合| 宅男噜噜噜66一区二区| 国产精品亚洲精品| 欧美电影免费观看高清| 香蕉久久夜色精品国产使用方法| 亚洲国产天堂久久综合网| 羞羞漫画18久久大片| 日韩网站在线| 曰韩精品一区二区| 国产精品免费一区二区三区在线观看| 噜噜噜躁狠狠躁狠狠精品视频 | 欧美承认网站| 久久精品视频在线| 亚洲在线一区二区三区| 亚洲激情网站| 一区二区视频免费在线观看 | 欧美国产亚洲另类动漫| 欧美一区二区三区免费视| 一区二区欧美亚洲| 亚洲激情亚洲| 亚洲国产精品福利| 久久五月激情| 久久精品系列| 久久精品综合| 久久精品人人爽| 久久精品国产精品亚洲精品| 亚洲欧美日韩在线播放| 一区二区三区.www| 一本一本久久| 亚洲午夜久久久| 一区二区欧美国产| 99综合电影在线视频| 亚洲乱码国产乱码精品精98午夜| 亚洲第一网站| 91久久久亚洲精品| 亚洲日本精品国产第一区| 亚洲国产精品高清久久久| 亚洲高清av在线| 亚洲精品美女91| 日韩一区二区精品在线观看| 亚洲精品久久久蜜桃| 日韩午夜av| 亚洲一卡二卡三卡四卡五卡| 一区二区三区国产精品| 一本一道久久综合狠狠老精东影业 | 免费在线观看精品| 欧美韩日一区二区三区| 欧美精选一区| 国产精品久久久999| 国产精品久久夜| 韩国在线视频一区| 亚洲国产精品一区二区www| 亚洲国产精品一区二区第一页 | 中文日韩在线| 香蕉乱码成人久久天堂爱免费| 欧美怡红院视频| 久久久久女教师免费一区| 欧美成人a∨高清免费观看| 欧美激情一区二区三区高清视频| 亚洲国产精品激情在线观看| 日韩一区二区免费看| 亚洲欧美美女| 欧美大片在线观看一区二区| 欧美日韩三级视频| 国产一区二区三区不卡在线观看 | 国产精品嫩草99av在线| 韩国精品一区二区三区| 亚洲三级影片| 午夜视频一区| 亚洲第一久久影院| 亚洲欧美春色| 欧美福利一区| 国产亚洲精品一区二555| 亚洲国产一二三| 欧美在线观看视频一区二区三区 | 亚洲国产精品va在线看黑人 | 亚洲人成在线观看| 欧美伊久线香蕉线新在线| 欧美福利视频| 狠狠入ady亚洲精品经典电影| 亚洲精品欧美极品| 欧美中文字幕久久| 99riav久久精品riav| 久久亚洲国产精品日日av夜夜| 欧美色图天堂网| 亚洲乱码精品一二三四区日韩在线 | 国产精品视频网站|