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

Uriel's Corner

Research Associate @ Harvard University / Research Interests: Computer Vision, Biomedical Image Analysis, Machine Learning
posts - 0, comments - 50, trackbacks - 0, articles - 594

POJ 1851 Map---計算幾何

Posted on 2010-09-27 02:23 Uriel 閱讀(452) 評論(0)  編輯 收藏 引用 所屬分類: POJ計算幾何
        ECUST ACHunter威武,今天哈爾濱現場賽一度rank6(算上旅游隊),后2h可惜了,福州繼續加油~~        

        繼續刷計算幾何。。不會的題目越來越多。。總算翻到個大水題,不過AC不足100,不知為何。。

        看完題發現大水,興奮地敲完之后發現題目給的半徑完全沒用到,想了下,果然腦殘。。有可能走出island那個圓的范圍了。。于是各種特判。。一交,WA。仔細檢查了下。。果然變量名敲錯一個字母,改了之后A了。。Ctrl+C,Ctrl+V的后果是。。好長好長的代碼。。

        這題是POJ 1000AC,還是這么菜,繼續努力 && 祈禱現場賽好運

        其他沒碰到trick,留下丑陋的代碼一份供后來者對拍。。思路還不清楚的可以參考Discuss~

//Problem: 1851  User: Uriel 
//Memory: 180K  Time: 16MS 
//Language: C++  Result: Accepted 

#include
<math.h>
#include
<stdio.h>
#include
<stdlib.h>
#define eps 1e-10

struct point{
    
double x,y;
}
s,e;

double r;

bool in_circle(double x,double y){
    
if(x*x+y*y-r*r<eps)return true;
    
return false;
}


int main(){
    
while(scanf("%lf",&r),fabs(r+1.0)>eps){
        scanf(
"%lf %lf %lf %lf",&s.x,&s.y,&e.x,&e.y);
        
if(fabs(s.x-e.x)<eps){
            
if(s.y-e.y<-eps)printf("north %.10lf\n",e.y-s.y);
            
else
                printf(
"south %.10lf\n",s.y-e.y);
            puts(
"");
            
continue;
        }

        
if(fabs(s.y-e.y)<eps){
            
if(s.x-e.x<-eps)printf("east %.10lf\n",e.x-s.x);
            
else
                printf(
"west %.10lf\n",s.x-e.x);
            puts(
"");
            
continue;
        }

        
//case 1
        if(s.x-e.x<-eps && s.y-e.y<-eps){
            
if((e.x-s.x)-(e.y-s.y)<-eps){
                
if(in_circle(s.x,s.y+(e.y-s.y)-(e.x-s.x))){
                    printf(
"north %.10lf\n",(e.y-s.y)-(e.x-s.x));
                    printf(
"northeast %.10lf\n",sqrt(2.0)*(e.x-s.x));
                }

                
else{
                    printf(
"northeast %.10lf\n",sqrt(2.0)*(e.x-s.x));
                    printf(
"north %.10lf\n",(e.y-s.y)-(e.x-s.x));
                }

            }

            
else if(fabs((e.x-s.x)-(e.y-s.y))<eps){
                printf(
"northeast %.10lf\n",sqrt(2.0)*(e.x-s.x));
            }

            
else{
                
if(in_circle(s.x+(e.x-s.x)-(e.y-s.y),s.y)){
                    printf(
"east %.10lf\n",(e.x-s.x)-(e.y-s.y));
                    printf(
"northeast %.10lf\n",sqrt(2.0)*(e.y-s.y));
                }

                
else{
                    printf(
"northeast %.10lf\n",sqrt(2.0)*(e.y-s.y));
                    printf(
"east %.10lf\n",(e.x-s.x)-(e.y-s.y));
                }

            }

            puts(
"");
            
continue;
        }

        
//case 2
        if(e.x-s.x<-eps && e.y-s.y>eps){
            
if((s.x-e.x)-(e.y-s.y)<-eps){
                
if(in_circle(s.x,s.y+(e.y-s.y)-(s.x-e.x))){
                    printf(
"north %.10lf\n",(e.y-s.y)-(s.x-e.x));
                    printf(
"northwest %.10lf\n",sqrt(2.0)*(s.x-e.x));
                }

                
else{
                    printf(
"northwest %.10lf\n",sqrt(2.0)*(s.x-e.x));
                    printf(
"north %.10lf\n",(e.y-s.y)-(s.x-e.x));
                }

            }

            
else if(fabs((s.x-e.x)-(e.y-s.y))<eps){
                printf(
"northwest %.10lf\n",sqrt(2.0)*(s.x-e.x));
            }

            
else{
                
if(in_circle(s.x-(s.x-e.x)+(e.y-s.y),s.y)){
                    printf(
"west %.10lf\n",(s.x-e.x)-(e.y-s.y));
                    printf(
"northwest %.10lf\n",sqrt(2.0)*(e.y-s.y));
                }

                
else{
                    printf(
"northwest %.10lf\n",sqrt(2.0)*(e.y-s.y));
                    printf(
"west %.10lf\n",(s.x-e.x)-(e.y-s.y));
                }

            }

            puts(
"");
            
continue;
        }

        
//case 3
        if(s.x-e.x>eps && s.y-e.y>eps){
            
if((s.x-e.x)-(s.y-e.y)<-eps){
                
if(in_circle(s.x,s.y-(s.y-e.y)+(s.x-e.x))){
                    printf(
"south %.10lf\n",(s.y-e.y)-(s.x-e.x));
                    printf(
"southwest %.10lf\n",sqrt(2.0)*(s.x-e.x));
                }

                
else{
                    printf(
"southwest %.10lf\n",sqrt(2.0)*(s.x-e.x));
                    printf(
"south %.10lf\n",(s.y-e.y)-(s.x-e.x));
                }

            }

            
else if(fabs((s.x-e.x)-(s.y-e.y))<eps){
                printf(
"southwest %.10lf\n",sqrt(2.0)*(s.x-e.x));
            }

            
else{
                
if(in_circle(s.x-(s.x-e.x)+(s.y-e.y),s.y)){
                    printf(
"west %.10lf\n",(s.x-e.x)-(s.y-e.y));
                    printf(
"southwest %.10lf\n",sqrt(2.0)*(s.y-e.y));
                }

                
else{
                    printf(
"southwest %.10lf\n",sqrt(2.0)*(s.y-e.y));
                    printf(
"west %.10lf\n",(s.x-e.x)-(s.y-e.y));
                }

            }

            puts(
"");
            
continue;
        }

        
//case 4
        if(e.x-s.x>eps && e.y-s.y<-eps){
            
if((e.x-s.x)-(s.y-e.y)<-eps){
                
if(in_circle(s.x,s.y-(s.y-e.y)+(e.x-s.x))){
                    printf(
"south %.10lf\n",(s.y-e.y)-(e.x-s.x));
                    printf(
"southeast %.10lf\n",sqrt(2.0)*(e.x-s.x));
                }

                
else{
                    printf(
"southeast %.10lf\n",sqrt(2.0)*(e.x-s.x));
                    printf(
"south %.10lf\n",(s.y-e.y)-(e.x-s.x));
                }

            }

            
else if(fabs((e.x-s.x)-(s.y-e.y))<eps){
                printf(
"southeast %.10lf\n",sqrt(2.0)*(e.x-s.x));
            }

            
else{
                
if(in_circle(s.x+(e.x-s.x)-(s.y-e.y),s.y)){
                    printf(
"east %.10lf\n",(e.x-s.x)-(s.y-e.y));
                    printf(
"southeast %.10lf\n",sqrt(2.0)*(s.y-e.y));
                }

                
else{
                    printf(
"southeast %.10lf\n",sqrt(2.0)*(s.y-e.y));
                    printf(
"east %.10lf\n",(e.x-s.x)-(s.y-e.y));
                }

            }

            puts(
"");
            
continue;
        }

    }

    
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>
            久久gogo国模裸体人体| 伊人久久婷婷| 亚洲最新视频在线播放| 久久久久久久性| 久久天天狠狠| 国产精品视频99| 亚洲一区二区三区色| 亚洲自拍电影| 国产一区二区三区四区三区四 | 欧美久久久久久久久久| 日韩亚洲国产欧美| 欧美伊久线香蕉线新在线| 国产亚洲欧洲997久久综合| 国产精品永久免费| 欧美激情在线狂野欧美精品| 亚洲一区二区精品在线| 亚洲免费网址| 日韩午夜电影av| 亚洲一区二区动漫| 久久国内精品视频| 在线视频中文亚洲| 欧美国产一区二区| 欧美一区=区| 免费成人av在线看| 久久国产精品久久精品国产| 99精品国产福利在线观看免费| 国产一区二区三区黄视频| 亚洲福利视频专区| 国产日产精品一区二区三区四区的观看方式 | 国产精品羞羞答答xxdd| 红桃视频亚洲| 国产精品香蕉在线观看| 亚洲高清一二三区| 欧美一级淫片播放口| 亚洲午夜在线视频| 影音先锋欧美精品| 在线亚洲一区| 亚洲一区二区在| 美女日韩欧美| 亚洲视频中文字幕| 亚洲天堂偷拍| 欧美www视频在线观看| 免费观看国产成人| 另类天堂视频在线观看| 久久久www成人免费无遮挡大片| 亚洲一区二区三区乱码aⅴ蜜桃女 亚洲一区二区三区乱码aⅴ | 一区二区三区四区五区精品| 欧美一区二区高清| 亚洲精品在线三区| 亚洲精品视频在线看| 久久精品一本久久99精品| 国产精品久久久久77777| 欧美日韩精品免费观看| 欧美精品激情| 在线观看视频一区| 久久久人成影片一区二区三区 | 毛片基地黄久久久久久天堂| 欧美一区日韩一区| 一区二区精品国产| 久久精品一区二区三区不卡牛牛| 国产精品久久久久久久久久三级 | 在线观看视频一区| 久久综合久久综合这里只有精品| 亚洲一区二区三区高清不卡| 国产精品国产三级国产aⅴ无密码| 日韩天堂av| 亚洲免费高清| 欧美午夜精品久久久久久孕妇| 欧美一级片在线播放| 久久久久久亚洲精品中文字幕| 国产乱码精品一区二区三区不卡| 亚洲欧美不卡| 欧美成人免费观看| 一区二区三区四区五区精品| 欧美日韩国产成人在线观看| 亚洲视频在线一区| 免费黄网站欧美| 久久久999成人| 精品999日本| 亚洲在线免费观看| 亚洲欧美日本伦理| 欧美日韩mp4| 亚洲欧美变态国产另类| 香蕉免费一区二区三区在线观看 | 欧美在线看片| 在线观看一区视频| 西西人体一区二区| 欧美在线高清| 亚洲激情av在线| 久久精品国产欧美亚洲人人爽 | 亚洲男人av电影| 黑人巨大精品欧美黑白配亚洲| 欧美成人免费在线观看| 欧美日韩情趣电影| 亚洲欧洲精品天堂一级| 欧美一区二区日韩| 久久国产欧美| 欧美国产日韩一区二区三区| 亚洲影院在线| 尤物精品国产第一福利三区| 亚洲另类春色国产| 娇妻被交换粗又大又硬视频欧美| 亚洲区免费影片| 午夜视黄欧洲亚洲| 亚洲欧洲综合另类在线| 亚洲欧美一区二区视频| 国精产品99永久一区一区| 午夜影院日韩| 欧美www在线| 久久精品国产成人| 欧美精品一区二| 久久一二三四| 国产精品久久久久久久久久ktv| 榴莲视频成人在线观看| 国产精品都在这里| 最新国产拍偷乱拍精品| 国内久久婷婷综合| 午夜激情亚洲| 亚洲欧美国产毛片在线| 欧美国产日产韩国视频| 99视频一区二区| 久久国产直播| 久久精品在线视频| 久久国产精品久久w女人spa| 一区二区高清| 欧美阿v一级看视频| 另类专区欧美制服同性| 国产精品一区二区在线观看| 亚洲激情网站| 亚洲精品黄网在线观看| 91久久久国产精品| 在线观看成人av| 久久精品国内一区二区三区| 久久er99精品| 国产偷国产偷亚洲高清97cao| 久久久久九九九| 国产精品自拍在线| 这里只有精品视频| 亚洲一区视频在线| 国产精品xnxxcom| 亚洲一区二区三区四区五区黄| 亚洲一区在线免费观看| 欧美性猛交xxxx乱大交蜜桃| 一区二区欧美日韩视频| 亚洲综合色丁香婷婷六月图片| 国产精品magnet| 亚洲欧美日韩精品综合在线观看 | 欧美黄色免费网站| 亚洲经典三级| 欧美日韩国产成人在线91| 亚洲最新中文字幕| 依依成人综合视频| 女生裸体视频一区二区三区| 亚洲国产经典视频| 欧美日韩国产成人在线| 日韩视频在线你懂得| 午夜精彩视频在线观看不卡 | 亚洲视频在线看| 国产精品成人aaaaa网站| 亚洲影音一区| 欧美xx69| 激情成人亚洲| 久久一区二区三区四区五区| 欧美日本高清一区| 亚洲一区视频| 久久亚洲免费| 一本色道久久综合亚洲精品小说| 国产精品v欧美精品v日韩精品| 欧美一级精品大片| 欧美激情a∨在线视频播放| 一区二区三区日韩欧美精品| 国产美女精品人人做人人爽| 久久综合伊人| 亚洲一区欧美| 亚洲国产精品久久精品怡红院| 国产欧美一区二区三区国产幕精品| 欧美一级片在线播放| 亚洲成色777777女色窝| 国产一区二区中文| 欧美激情黄色片| 亚洲免费在线观看| 欧美国产一区二区在线观看| 香蕉久久一区二区不卡无毒影院 | 欧美日韩第一区| 欧美在线视频a| 99国内精品| 免费在线一区二区| 欧美一区二区三区免费视| 亚洲国产人成综合网站| 国产日韩久久| 欧美日韩一区二区在线播放| 久久精品国内一区二区三区| 亚洲一级在线| 亚洲精品日产精品乱码不卡| 免费欧美网站| 久久免费99精品久久久久久| 亚洲综合首页| 一本色道久久| 99国产精品国产精品毛片| 永久免费精品影视网站|