HDU 1067 Gap BFS+Hash

感觉可以用bfs暴力,一开始写了一个很暴力的bfs,hash判重,本地跑了几组数据发现至少要2s才能过,交上去估计要TLE,试探性的交了一发1A了,原来时限是10s,我看成1s了,真是逗逼。。。还一直不敢写

#include <cstdio>
#include <cstring>
#include <iostream>
#include <map>
#include <set>
#include <vector>
#include <string>
#include <queue>
#include <deque>
#include <bitset>
#include <list>
#include <cstdlib>
#include <climits>
#include <cmath>
#include <ctime>
#include <algorithm>
#include <stack>
#include <sstream>
#include <numeric>
#include <fstream>
#include <functional>

using namespace std;

#define MP make_pair
#define PB push_back
typedef long long LL;
typedef unsigned long long ULL;
typedef vector<int> VI;
typedef pair<int,int> pii;
const int INF = INT_MAX / 3;
const double eps = 1e-8;
const LL LINF = 1e17;
const double DINF = 1e60;
const int maxn = 5, maxm = 9;
const int n = 4,m = 8;
const int maxq = 65536;
int mp[maxn][maxm];

struct Node {
    int data[maxn][maxm],dis;
    Node(int val[maxn][maxm],int dis):dis(dis) {
        for(int i = 1;i <= n;i++) {
            for(int j = 1;j <= m;j++) {
                data[i][j] = val[i][j];
            }
        }
    }

    Node() {
        for(int i = 1;i <= n;i++) {
            for(int j = 1;j < m;j++) {
                data[i][j] = i * 10 + j;
            }
            data[i][8] = 0;
        }
    }

    bool operator == (const Node &node) const {
        for(int i = 1;i <= n;i++) {
            for(int j = 1;j <= m;j++) {
                if(node.data[i][j] != data[i][j]) return false;
            }
        }
        return true;
    }
};

const Node tar;

Node q[maxq], val[maxq];
int head[maxq], nxt[maxq], sz;
int qs,qe;

int gethash(const Node &now) {
    int ret = 0;
    for(int i = 1;i <= n;i++) {
        for(int j = 1;j <= m;j++) {
            ret = (ret << 6) + now.data[i][j];
        }
    }
    return ret & (maxq - 1);
}

bool exist(const Node &now) {
    int hc = gethash(now);
    for(int i = head[hc];~i;i = nxt[i]) {
        if(val[i] == now) return true;
    }
    val[sz] = now; nxt[sz] = head[hc];
    head[hc] = sz++;
    return false;
}

void expand(int x,int y,Node now) {
    bool found = false;
    int val = now.data[x][y - 1] + 1;
    for(int i = 1;i <= n;i++) {
        for(int j = 1;j <= m;j++) if(now.data[i][j] == val) {
            now.data[i][j] = 0;
            now.data[x][y] = val;
            found = true;
            break;
        }
    }
    if(!found) return;
    if(!exist(now)) {
        now.dis++;
        q[qe % maxq] = now;
        qe++;
    }
}

int solve() {
    qs = qe = sz = 0;
    q[qe++] = Node(mp,0);
    memset(head,-1,sizeof(head));
    while(qs < qe) {
        Node now = q[qs % maxq]; qs++;
        if(now == tar) return now.dis;
        for(int i = 1;i <= n;i++) {
            for(int j = 1;j <= m;j++) if(now.data[i][j] == 0) {
                expand(i,j,now);
            }
        }
    }
    return -1;
}

int main() {
    int T; scanf("%d",&T);
    while(T--) {
        for(int i = 1;i <= n;i++) {
            for(int j = 2;j <= m;j++) {
                scanf("%d",&mp[i][j]);
                if(mp[i][j] % 10 == 1) {
                    mp[mp[i][j] / 10][1] = mp[i][j];
                    mp[i][j] = 0;
                }
            }
        }
        printf("%d\n",solve());
    }
    return 0;
}

 

posted @ 2014-09-01 21:28  acm_roll  阅读(277)  评论(0编辑  收藏  举报