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

c++&oi

USACO5.3.2window

最方便的快捷的方法,當然是離散化。
C++里面有些東西還是不熟啊,比如那個switch
/*
USER: zyn19961
TASK: window
LANG: C++
*/
#include<iostream>
#include<fstream>
#include<cstring>
#include<cstdlib>
#include<algorithm>
//
    using namespace std;
#define MM(a,i) memset(a,i,sizeof(a))
#define FOR(i,l,r) for (int i=(l);i<=(r);i++)
#define PFOR(p,a,next) for(int p=a;p;p=next[p])
//
    typedef long long int64;
    const int INF=~0U>>2;
//
    int maxp=0, minp=0;//maxp最后面的, minp最前面的
    class Window{
        public:
        int x1,y1,x2,y2,pos;
        void init(int a, int b, int c, int d){
            if(a>c)swap(a,c);if(b>d)swap(b,d);
            x1=a,y1=b,x2=c,y2=d,pos=minp--;}
        double area(){return (x2-x1)*(y2-y1);}
        };
    Window  window[256];
    bool map[300][300];
    int hx[50000],hy[50000];
    int fx[1000], fy[1000];
    double query(char ch){
        MM(hx,0),MM(hy,0),MM(fx,0),MM(fy,0);
        int fxn=0,fyn=0;
        //step 1, 找出在ch前面的窗口
        //step 2, 離散化
        FOR(i,0,255)
            if(window[i].pos!=-INF)// && i != ch){
                if(window[i].pos<=window[ch].pos)
                    hx[window[i].x1]=true,hx[window[i].x2]=true,
                    hy[window[i].y1]=true,hy[window[i].y2]=true;
        FOR(i,0,32767){
            if(hx[i])fx[fxn++]=i,hx[i]=fxn-1;//else hx[i]=-1;
            if(hy[i])fy[fyn++]=i,hy[i]=fyn-1;//else hy[i]=-1;
            }
        //step 3, fillflood
        MM(map,false);
        FOR(i,0,255)
            if(window[i].pos!=-INF&&i!=ch){
                if(window[i].pos<window[ch].pos){
                    int bx=hx[window[i].x1],
                        by=hy[window[i].y1];
                    for(int x=bx;fx[x]<window[i].x2; x++)
                        for(int y=by;fy[y]<window[i].y2;y++)
                            map[x][y]=true;
                }
            }
        //step 4, 計算面積百分比
        double area=window[ch].area();
        int bx=hx[window[ch].x1],
            by=hy[window[ch].y1];
        double white=0.0;
        for(int x=bx;fx[x]<window[ch].x2;x++)
            for(int y=by;fy[y]<window[ch].y2;y++){
                if(!map[x][y])
                    white+=(fx[x+1]-fx[x])*(fy[y+1]-fy[y]);
            }
        return white/area;
        }
    int main(){
        freopen("window.in","r",stdin);
        freopen("window.out","w",stdout);
        char op, ch;
        int x1,y1,x2,y2,cnt=0;
        while(scanf("%c",&op) != EOF){
            if (op!='s')
                scanf("(%c,%d,%d,%d,%d)\n",&ch,&x1,&y1,&x2,&y2);
            else
                scanf("(%c)\n",&ch);
            switch(op){
                case 'w': window[ch].init(x1,y1,x2,y2);break;
                case 't': window[ch].pos=minp--; break;
                case 'b': window[ch].pos=maxp++; break;
                case 'd': window[ch].pos=-INF;   break;
                case 's': printf("%.3f\n", query(ch)*100); break;
                default: break;
                }
            }
        return 0;
        }

posted on 2012-04-27 22:29 zyn.cpp 閱讀(321) 評論(0)  編輯 收藏 引用


只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


<2012年3月>
26272829123
45678910
11121314151617
18192021222324
25262728293031
1234567

導航

統計

常用鏈接

留言簿

隨筆檔案(57)

文章檔案(13)

搜索

最新評論

閱讀排行榜

評論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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| 久热精品视频在线观看一区| 久久人体大胆视频| 欧美1区免费| 欧美日韩视频免费播放| 国产精品青草久久| 狠狠综合久久| 亚洲精品1234| 中文亚洲字幕| 亚洲欧美在线高清| 老司机免费视频久久| 欧美第十八页| 亚洲美女网站| 欧美在线视频导航| 欧美国产一区视频在线观看| 欧美午夜久久| 一区二区三区在线视频观看| 亚洲激情视频在线播放| 亚洲小少妇裸体bbw| 久久精品久久99精品久久| 老司机精品导航| 一区二区免费看| 欧美专区在线| 欧美三级电影精品| 在线观看国产成人av片| 这里只有精品在线播放| 久久久99精品免费观看不卡| 欧美成人精品福利| 亚洲一区999| 美女视频黄a大片欧美| 国产精品九色蝌蚪自拍| 在线精品观看| 亚洲欧洲av一区二区三区久久| 久久久青草婷婷精品综合日韩 | 欧美伊人精品成人久久综合97| 久久婷婷国产麻豆91天堂| 亚洲日本一区二区| 妖精成人www高清在线观看| 久久国产综合精品| 欧美综合二区| 亚洲免费综合| 性xx色xx综合久久久xx| 亚洲第一黄色| 久久国产精品毛片| 国产精品国产三级国产普通话三级 | 久久影视三级福利片| 99re亚洲国产精品| 你懂的成人av| 亚洲大胆女人| 久久综合色8888| 欧美亚洲在线| 国产视频精品免费播放| 亚洲免费在线观看| 一本综合精品| 欧美日韩国产不卡在线看| 亚洲国产精品久久久久婷婷老年| 久久高清福利视频| 小黄鸭精品aⅴ导航网站入口| 国产精品二区影院| 亚洲欧美一级二级三级| 亚洲精品免费一区二区三区| 欧美高清你懂得| 亚洲韩国一区二区三区| 欧美成人黄色小视频| 另类激情亚洲| 亚洲国产一区二区视频| 亚洲第一偷拍| 欧美破处大片在线视频| 一区二区三区四区五区视频| 日韩一级精品| 国产精品网站在线| 久久精品一区| 美女999久久久精品视频| 亚洲国产成人tv| 亚洲黑丝在线| 欧美视频在线一区二区三区| 午夜精品久久久久久久久久久久| 亚洲欧美美女| 亚洲国产精品悠悠久久琪琪| 亚洲欧洲精品一区二区| 国产精品白丝jk黑袜喷水| 欧美一区二区三区喷汁尤物| 性一交一乱一区二区洋洋av| 在线观看日产精品| 亚洲三级影院| 国产伦精品一区二区三区视频黑人| 久久九九精品99国产精品| 久久综合亚州| 亚洲综合色丁香婷婷六月图片| 午夜在线成人av| 亚洲电影天堂av| 日韩一区二区精品| 狠狠狠色丁香婷婷综合久久五月| 亚洲国产高清自拍| 国产模特精品视频久久久久| 欧美人与禽性xxxxx杂性| 亚洲欧美伊人| 免费日韩av| 午夜国产精品视频免费体验区| 久久久久久久成人| 亚洲一品av免费观看| 久久成人资源| 亚洲图中文字幕| 美女日韩欧美| 久久精品一二三区| 欧美日韩免费网站| 美女日韩欧美| 国产精品美女久久久久久免费| 欧美成人精品h版在线观看| 欧美视频免费看| 欧美激情第1页| 国产亚洲一区在线播放| 99成人免费视频| 亚洲黄网站在线观看| 性欧美长视频| 亚洲欧美日韩一区在线观看| 欧美成人蜜桃| 欧美不卡激情三级在线观看| 国产美女一区| 亚洲天天影视| 亚洲一级在线观看| 欧美日韩在线免费| 亚洲七七久久综合桃花剧情介绍| 韩国女主播一区二区三区| 亚洲一区二区黄| 亚洲一区二区3| 欧美日本久久| 亚洲破处大片| av成人激情| 欧美精品三级日韩久久| 欧美激情一区三区| 亚洲精品乱码久久久久| 老司机精品导航| 免费观看成人| 在线欧美电影| 久久综合一区二区三区| 久久天天躁夜夜躁狠狠躁2022| 国产欧美亚洲一区| 午夜一区二区三视频在线观看 | 一区二区三区黄色| 一区二区三区毛片| 欧美日韩一区二区精品| 日韩写真视频在线观看| 亚洲无限av看| 国产精品麻豆成人av电影艾秋| 亚洲色图制服丝袜| 久久se精品一区精品二区| 国产日韩欧美麻豆| 久久久免费av| 亚洲黄色免费| 亚洲一区二区三区高清不卡| 欧美亚韩一区| 欧美在线观看你懂的| 免费亚洲电影| 亚洲视频在线观看三级| 国产精品久久久久久久7电影| 亚洲综合成人在线| 久久蜜桃资源一区二区老牛| 亚洲激情网站免费观看| 欧美大色视频| 欧美视频在线视频| 日韩午夜在线电影| 欧美在线亚洲在线| 亚洲人www| 欧美视频中文一区二区三区在线观看 | 欧美成人亚洲成人日韩成人| 亚洲精品中文字幕女同| 欧美亚洲免费电影| 亚洲第一区中文99精品| 欧美国产亚洲另类动漫| 亚洲综合三区| 亚洲高清不卡在线观看| 午夜在线观看免费一区| 在线精品国产欧美| 欧美日韩在线三区| 久久一区二区三区国产精品| 亚洲日本成人| 久久亚洲色图| 亚洲欧美经典视频| 亚洲大胆人体在线| 国产欧美日韩视频一区二区| 欧美成人午夜77777| 欧美在线看片a免费观看| 亚洲精品男同| 裸体丰满少妇做受久久99精品| 在线综合+亚洲+欧美中文字幕| 韩国一区二区三区在线观看| 欧美日韩在线亚洲一区蜜芽| 久久久久国产一区二区| 亚洲区一区二| 蜜臀av国产精品久久久久| 亚洲欧美中文日韩在线| 日韩午夜视频在线观看|