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

pku 3501 Escape from Enemy Territory 二分+BFS

題意:
網格圖上有N個敵人的據點。求從起點到終點路徑中到敵人據點Manhattan distance: dist((x1, y1), (x2, y2)) = |x2x1| + |y2y1|. 最長距離,如果有重復,則使得路徑長度最短。
解法:
二分路徑中到敵人據點的最短距離,然后用BFS check
注意在chk時可以開個bool數組來標記,不用標記到所有的不合法點,只要標記其輪廓就可以了,這樣可以降低復雜度的階
代碼:
 1# include <cstdio>
 2# include <cstring>
 3using namespace std;
 4int n,w,h,sx,sy,ex,ey;
 5int p[10001][2];
 6int q[1000005][2];
 7int map[1001][1001];
 8# define abs(a) ((a)>0?(a):-(a))
 9# define legal(a,b) ((a)>=0&&(a)<w&&(b)>=0&&(b)<h)
10int chk(int limit)
11{
12    memset(map,-1,sizeof(map));
13    for(int i=0;i<n;i++)
14        for(int l=0;l<=limit;l++)
15        {
16            if(legal(p[i][0]-l,p[i][1]+limit-l))
17               map[p[i][0]-l][p[i][1]+limit-l]=-2;
18            if(legal(p[i][0]+l,p[i][1]+limit-l))
19               map[p[i][0]+l][p[i][1]+limit-l]=-2;
20            if(legal(p[i][0]-l,p[i][1]-limit+l))
21               map[p[i][0]-l][p[i][1]-limit+l]=-2;
22            if(legal(p[i][0]+l,p[i][1]-limit+l))
23               map[p[i][0]+l][p[i][1]-limit+l]=-2;
24        }

25    for(int i=0;i<n;i++)
26      if(abs(p[i][0]-sx)+abs(p[i][1]-sy)<=limit||abs(p[i][0]-ex)+abs(p[i][1]-ey)<=limit) return -1;
27    int s=-1,e=-1;
28    e++;
29    q[e][0]=sx;
30    q[e][1]=sy;
31    map[sx][sy]=0;
32    while(s!=e)
33    {
34       s++;
35       int x=q[s][0],y=q[s][1];
36       if(legal(x-1,y)&&map[x-1][y]==-1)
37       {
38         e++;
39         q[e][0]=x-1;
40         q[e][1]=y;
41         map[q[e][0]][q[e][1]]=map[x][y]+1;
42       }

43       if(legal(x+1,y)&&map[x+1][y]==-1)
44       {
45         e++;
46         q[e][0]=x+1;
47         q[e][1]=y;
48         map[q[e][0]][q[e][1]]=map[x][y]+1;
49       }

50       if(legal(x,y-1)&&map[x][y-1]==-1)
51       {
52         e++;
53         q[e][0]=x;
54         q[e][1]=y-1;
55         map[q[e][0]][q[e][1]]=map[x][y]+1;
56       }

57       if(legal(x,y+1)&&map[x][y+1]==-1)
58       {
59         e++;
60         q[e][0]=x;
61         q[e][1]=y+1;
62         map[q[e][0]][q[e][1]]=map[x][y]+1;
63       }

64    }

65    return map[ex][ey]==-2||map[ex][ey]==-1?-1:map[ex][ey];
66}

67int main()
68{
69    int test;
70    scanf("%d",&test);
71    while(test--)
72    {
73        scanf("%d%d%d%d%d%d%d",&n,&w,&h,&sx,&sy,&ex,&ey);
74        for(int i=0;i<n;i++)
75          scanf("%d%d",&p[i][0],&p[i][1]);
76        int s=0,e=(w>h?w:h)-1;
77        while(s<=e)
78        {
79           int mid=(s+e)>>1;
80           if(chk(mid)!=-1) s=mid+1;
81           else e=mid-1;
82        }

83        printf("%d %d\n",e+1,chk(e));
84    }
    
85    return 0;
86}

87

posted on 2010-12-02 22:47 yzhw 閱讀(283) 評論(0)  編輯 收藏 引用 所屬分類: search

<2011年1月>
2627282930311
2345678
9101112131415
16171819202122
23242526272829
303112345

導航

統計

公告

統計系統

留言簿(1)

隨筆分類(227)

文章分類(2)

OJ

最新隨筆

搜索

積分與排名

最新評論

閱讀排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲精品1区2区| 牛人盗摄一区二区三区视频| 久久久精品国产一区二区三区 | 亚洲高清免费在线| 亚洲国产精品久久| 亚洲精品一区二区三区av| 日韩特黄影片| 亚洲午夜精品17c| 亚洲午夜国产成人av电影男同| 一本色道久久综合狠狠躁篇怎么玩| 亚洲人被黑人高潮完整版| 亚洲伦理在线免费看| 亚洲视频一区二区| 欧美在线视频观看免费网站| 久久亚洲精品视频| 亚洲国产一区二区在线| 日韩视频一区二区三区在线播放 | 久久成人免费网| 午夜精品久久| 久久久国产一区二区三区| 久久综合色88| 欧美日韩一区二区免费在线观看| 国产精品白丝黑袜喷水久久久 | 久久精品国产一区二区电影| 奶水喷射视频一区| 国产精品老牛| 亚洲区在线播放| 亚洲欧美在线播放| 欧美大片第1页| 亚洲视频免费看| 久久综合影音| 国产精品影音先锋| 亚洲人成人99网站| 久久成人资源| 亚洲性感美女99在线| 久久精品一区二区三区中文字幕| 久久精品免费电影| 欧美精品久久99| 国产一级揄自揄精品视频| 亚洲精品日韩激情在线电影| 欧美在线你懂的| 一本色道**综合亚洲精品蜜桃冫| 欧美中文字幕不卡| 国产精品久久久久久妇女6080 | 黄色成人精品网站| 亚洲一区二区三区四区视频| 你懂的国产精品| 羞羞色国产精品| 欧美午夜免费影院| 亚洲巨乳在线| 欧美激情欧美激情在线五月| 欧美一区二区三区四区在线 | 午夜精品久久久久久久99热浪潮| 欧美成人一区二区三区片免费| 午夜在线观看免费一区| 国产精品99一区| av不卡免费看| 亚洲片区在线| 欧美成人免费大片| 亚洲第一黄网| 另类尿喷潮videofree| 欧美亚洲视频在线观看| 国产欧美1区2区3区| 欧美一区二区在线看| 亚洲无线一线二线三线区别av| 亚洲激情av在线| 午夜久久一区| 亚洲一级一区| 国产精品另类一区| 一区二区三区日韩精品| 亚洲国产精品一区二区久| 另类亚洲自拍| 亚洲国产专区校园欧美| 亚洲成色精品| 欧美精品日韩一区| 999在线观看精品免费不卡网站| 欧美电影免费网站| 欧美激情第五页| 亚洲视频axxx| 亚洲专区免费| 伊人激情综合| 亚洲国产导航| 欧美三级日本三级少妇99| 亚洲一区二区不卡免费| 亚洲一级网站| 亚洲大片在线| 亚洲精品美女在线观看| 欧美日韩在线视频一区二区| 午夜精品在线视频| 久久精品人人做人人爽| 91久久视频| 亚洲视频网在线直播| 国产嫩草一区二区三区在线观看| 久久国产综合精品| 久久综合九色欧美综合狠狠| 一二三区精品福利视频| 欧美一级二级三级蜜桃| 亚洲国产精选| 亚洲午夜av| 亚洲国产欧美一区二区三区丁香婷| 日韩亚洲欧美高清| 一区在线电影| 亚洲婷婷免费| 亚洲精品影视在线观看| 亚洲欧美99| 一本色道久久加勒比88综合| 校园激情久久| 一本色道久久加勒比精品| 久久久久九九视频| 亚洲欧美日本国产有色| 欧美aa国产视频| 久久精品91| 欧美日韩中文字幕精品| 免费久久精品视频| 国产日韩精品一区观看| 亚洲国产一区二区三区在线播 | 日韩一级免费| 久久不射电影网| 亚洲免费影视| 欧美日韩一区二区三区四区五区| 久久久午夜精品| 国产精品普通话对白| 亚洲精品日本| 亚洲美女少妇无套啪啪呻吟| 久久久久久高潮国产精品视| 亚洲欧美中文字幕| 欧美色精品在线视频| 欧美高清免费| 在线欧美小视频| 国产伦精品一区二区| 亚洲日本成人| 亚洲高清在线视频| 欧美一区亚洲一区| 亚洲欧美激情精品一区二区| 欧美日本成人| 91久久夜色精品国产网站| 亚洲国产精品电影| 久久久蜜桃一区二区人| 久久精品一区二区三区四区| 国产精品视频一区二区三区| 亚洲特级毛片| 欧美在线免费观看视频| 国产欧美一区二区精品性 | 久久久国产成人精品| 国产精品乱码久久久久久| 99v久久综合狠狠综合久久| 在线视频你懂得一区| 欧美日韩国产精品专区| 日韩视频精品在线| 午夜久久久久久| 国产一区二区三区网站| 久久久久久自在自线| 欧美88av| 99在线热播精品免费| 欧美午夜精品久久久久久人妖| 99热这里只有精品8| 亚洲欧美日韩国产一区二区三区| 国产精品嫩草99a| 久久精品国产清高在天天线| 女主播福利一区| 亚洲伦理中文字幕| 国产精品视频男人的天堂| 香蕉视频成人在线观看| 欧美成年网站| 在线观看中文字幕不卡| 久久精品理论片| 亚洲电影免费| 亚洲一区日韩| 国产在线精品成人一区二区三区| 久久亚洲图片| 夜夜嗨av色一区二区不卡| 欧美一区二区黄| 亚洲人成网站色ww在线| 欧美色视频日本高清在线观看| 欧美在线播放高清精品| 亚洲高清免费视频| 午夜在线精品| 亚洲电影视频在线| 欧美日韩视频一区二区| 欧美在线综合视频| 亚洲精品影院在线观看| 久久久久久久精| 一区二区三区日韩精品视频| 一区二区在线观看视频在线观看| 欧美日韩不卡合集视频| 久久精品91久久香蕉加勒比| 亚洲精品视频一区二区三区| 久久九九免费视频| 夜色激情一区二区| 极品日韩久久| 国产精品久久久久久久久免费樱桃| 麻豆成人综合网| 午夜免费久久久久| 99视频超级精品| 亚洲国产小视频在线观看| 久久精品国产免费观看| 99在线观看免费视频精品观看| 韩国女主播一区二区三区| 亚洲亚洲精品在线观看 | 国内精品写真在线观看|