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

算法學社
記錄難忘的征途
posts - 141,comments - 220,trackbacks - 0
題目描述:
    給一個大小為n*m(n,m < 2000)的棋盤,有k(K<100,000)次操作。每次在位置(x,y)加入一個點,如果x,y已經有點了,那么加入的點需要滿足:
        1. 與x,y的曼哈頓距離最近。
        2. 如果滿足條件1的點有多個,那么要求x最小。
        3. 如果滿足條件2的點有多個,那么要求y最小。
算法分析:
    
    從x開始,對每行r暴力尋找與(r,y)距離最近的點。
    如果使用并查集來維護,每行查找時間就是O(1)。
    如果|x-r|大于現有最優值,那么現有最優值就是答案,停止查找。
    最多查找的行數是sqrt(k),也就是可能的最遠距離。
    其實如果長寬高度差距較大,最遠距離可能很遠,但是查找行數就不會超過高度了。
    如果高度比長度大,那么將棋盤翻轉就可以了。
    總時間復雜度為O(K*sqrt(K))
#include<iostream>
#include<cstdlib>
#include<cstdio>
using namespace std;
const int N = 2005;
int P[N][N][2];
int n,m,t,ex,ey;
int dis(int x,int y){return abs(ex-x) + abs(ey-y);}
bool flag ;
int find(int x,int y,int p){return P[x][y][p] == y ? y : P[x][y][p] = find(x,P[x][y][p],p); }
inline void chk(int &ans, int nx, int ny,int &x, int &y){
    int d = dis(nx,ny);
    if(ans > d) {ans = d, x = nx, y = ny;}
    else if(ans == d) {
        if(!flag){
            if(nx < x) {x = nx, y = ny;}
            else if(nx == x && ny < y) {x = nx, y= ny;}
        }
        else {
            if(ny < y) {x = nx, y = ny;}
            else if(ny == y && nx < x) {x = nx;}
        }
    }
}
inline void update(int r, int& ans, int &x, int &y){
    int nx = r, ny = find(r,ey,0);
    if(ny <= m ){ chk(ans,nx,ny, x, y);}
    ny = find(r,ey,1);
    if(ny > 0 ){ chk(ans,nx,ny, x, y);}
}
int main(){
    for(int i=0;i<N;i++)
        for(int j=0;j<N;j++)
            P[i][j][0] = P[i][j][1] = j;
    scanf("%d%d%d",&n,&m,&t);
     flag = 0; int cnt =0;
    if(n>m) {swap(n,m); flag = 1;}
    int test = 0;
    while(t--){
        int x ,y;
        scanf("%d%d",&x,&y);
        if(flag) swap(x,y);
        ex = x, ey = y;
        int d = 0, ans = ~0u>>2, nx, ny;
        while(d <= ans && d<n) {
            int r = x - d;
            if(r > 0 && r <= n) update(r , ans, nx, ny);
            r = x + d;
            if(r > 0 && r <= n) update(r , ans, nx, ny);
            d ++;
        }
        P[nx][ny][0] = ny+1;
        P[nx][ny][1] = ny-1;
        if(flag) swap(nx,ny);
        printf("%d %d\n",nx,ny);
    }
}
    其中判斷的部分一定要盡量優,之前一直超時是因為沒用把判斷的函數設置為內聯函數。
posted on 2012-07-21 15:02 西月弦 閱讀(327) 評論(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| 亚洲资源av| 久久青草欧美一区二区三区| 91久久久久久久久| 国内精品福利| 国产在线视频不卡二| 国内一区二区在线视频观看| 国产夜色精品一区二区av| 国产一区二区福利| 激情亚洲网站| 亚洲日本一区二区三区| 日韩天堂在线观看| 亚洲视频大全| 久久九九国产精品怡红院| 毛片精品免费在线观看| 欧美激情麻豆| 一区二区三区.www| 午夜一区不卡| 99国产精品99久久久久久粉嫩| 亚洲视频精品| 久久久久国产精品一区| 美女图片一区二区| 亚洲精品四区| 欧美一区三区三区高中清蜜桃| 美国十次成人| 国产欧美在线观看| 亚洲精品一区二区三区蜜桃久| 午夜视频一区二区| 亚洲电影观看| 99视频精品全部免费在线| 久久国产日韩欧美| 欧美天天综合网| 亚洲丶国产丶欧美一区二区三区 | 亚洲精品少妇30p| 亚洲午夜高清视频| 欧美国产在线视频| 国产一区视频网站| 亚洲制服av| 亚洲国内在线| 久久影视精品| 国产欧美日韩伦理| 亚洲天堂偷拍| 亚洲国产精品久久久久婷婷老年| 欧美在线亚洲综合一区| 国产精品久久久一区麻豆最新章节 | 国产偷自视频区视频一区二区| 99国产精品久久久久老师| 美国十次了思思久久精品导航| 99在线精品视频| 欧美福利在线| 亚洲国产第一| 久久人人爽爽爽人久久久| 亚洲一区二区三区精品在线| 欧美精品一区二区三区在线看午夜| 亚洲春色另类小说| 免费短视频成人日韩| 久久精品一区二区国产| 国产视频自拍一区| 欧美在线影院在线视频| 亚洲在线电影| 国产裸体写真av一区二区| 亚洲自拍偷拍一区| 一区二区三区精品视频| 国产精品v欧美精品v日韩| 中文在线不卡视频| 一本色道久久88精品综合| 欧美日韩在线不卡一区| 亚洲在线观看免费视频| 亚洲图片在区色| 国产精品免费观看视频| 亚洲综合社区| 午夜精品久久久久久久男人的天堂| 亚洲视频一区| 国产精品伦理| 欧美一区永久视频免费观看| 亚洲永久字幕| 国内成人在线| 欧美激情欧美狂野欧美精品| 欧美成人一品| 亚洲在线观看| 欧美在线黄色| 亚洲激情在线观看| 亚洲精品影院在线观看| 国产精品二区三区四区| 欧美在线黄色| 久久久久久久高潮| 日韩系列在线| 亚洲影音先锋| 一区视频在线| 亚洲精品视频一区| 国产精品一级二级三级| 老色鬼久久亚洲一区二区| 欧美国产精品人人做人人爱| 亚洲在线视频网站| 久久久久久久综合| 夜夜嗨av一区二区三区中文字幕| 亚洲视频一二三| 最新日韩中文字幕| 亚洲性夜色噜噜噜7777| 亚洲电影在线观看| 一区二区三区精品国产| 在线精品在线| 亚洲在线不卡| 99综合电影在线视频| 性久久久久久| 99热这里只有成人精品国产| 欧美一区二区在线免费播放| 日韩视频一区二区三区在线播放 | 免费久久99精品国产自在现线| 亚洲淫性视频| 鲁大师成人一区二区三区| 亚洲专区欧美专区| 美女视频网站黄色亚洲| 久久国产黑丝| 欧美日韩在线精品一区二区三区| 蜜臀av性久久久久蜜臀aⅴ四虎| 欧美午夜精品理论片a级按摩| 卡一卡二国产精品| 国产女主播在线一区二区| 日韩亚洲国产欧美| 亚洲三级毛片| 久久蜜桃av一区精品变态类天堂| 亚洲宅男天堂在线观看无病毒| 欧美国产大片| 亚洲黄色在线看| 在线精品国精品国产尤物884a| 欧美一级专区免费大片| 亚洲欧美日本日韩| 欧美日韩一区二区在线观看| 亚洲国产精品第一区二区三区| 精品成人一区二区三区| 久久高清福利视频| 久久久久中文| 国产综合自拍| 久久久国产精品亚洲一区| 久久久久久婷| 一区二区三区我不卡| 国产日韩欧美在线视频观看| 国产精品99久久久久久久久久久久| 久久久亚洲影院你懂的| 久久久精品国产免费观看同学| 国产精品一级二级三级| 亚洲一区视频| 欧美在线一二三四区| 国产一区二区三区黄| 久久精品欧美日韩精品| 美女日韩欧美| 最新亚洲电影| 欧美日韩一区在线观看| 亚洲天天影视| 久久久噜噜噜久久中文字免| 一区二区视频欧美| 欧美电影资源| 亚洲视频www| 久久九九全国免费精品观看| 国精品一区二区三区| 久久免费视频在线观看| 欧美风情在线观看| 亚洲美女黄色| 国产精品毛片a∨一区二区三区|国| 亚洲午夜精品17c| 久久蜜桃精品| 亚洲美女在线视频| 国产精品久久久久一区二区三区共| 午夜精品剧场| 欧美激情片在线观看| 亚洲影视中文字幕| 黑人操亚洲美女惩罚| 欧美精品一卡二卡| 亚洲欧美综合网| 亚洲丰满少妇videoshd| 亚洲欧美日韩视频二区| 136国产福利精品导航网址应用| 免费视频亚洲| 亚洲午夜电影网| 欧美国产精品v| 午夜精品久久久久久久99热浪潮 | 亚洲久久视频| 国产免费成人| 欧美精品一区二区在线播放| 亚洲欧美国产精品桃花| 欧美激情一区二区三区不卡| 欧美一区二区三区免费视| 亚洲人成人一区二区三区| 国产精品一香蕉国产线看观看| 久久久久成人精品| 亚洲一级在线观看| 亚洲国产欧美日韩精品| 久久精品亚洲一区二区| 在线综合亚洲欧美在线视频| 激情欧美一区| 国产精品亚洲人在线观看| 欧美激情一区二区三区在线| 欧美呦呦网站| 亚洲一区免费| 日韩视频在线免费| 亚洲国产成人porn| 美女黄毛**国产精品啪啪| 久久国产黑丝| 欧美在线91|