首页 > 编程语言 > 详细

北京网络赛G BOXES 状态压缩+有序BFS+高维数组判重

时间:2016-03-15 20:51:56      阅读:240      评论:0      收藏:0      [点我收藏+]
#include <bits/stdc++.h>
using namespace std;
int vis1[7];
int vis2[7][7];
int vis3[7][7][7];
int vis4[7][7][7][7];
int vis5[7][7][7][7][7];
int vis6[7][7][7][7][7][7];
int vis7[7][7][7][7][7][7][7];
struct node{
    int a[7];
    int step;
};
bool check(int a[],int num,int step){ //检查有没有走过
    if(num==1){
        if(vis1[a[0]]>=0) return true;
        else{vis1[a[0]]=step;return false;}
    }
    if(num==2){
        if(vis2[a[0]][a[1]]>=0) return true;
        else {vis[a[0]][a[1]]=step;return false;}
    }
    if(num==3){
        if(vis3[a[0]][a[1]][a[2]]>=0) return true;
        else {vis[a[0]][a[1]][a[2]]=step;return false;}
    }
    if(num==4){
        if(vis4[a[0]][a[1]][a[2]][a[3]]>=0) return true;
        else {vis[a[0]][a[1]][a[2]][a[3]]=step;return false;}
    }
    if(num==5){
        if(vis5[a[0]][a[1]][a[2]][a[3]][a[4]]>=0) return true;
        else {vis5[a[0]][a[1]][a[2]][a[3]][a[4]]=step;return false;}
    }
    if(num==6){
        if(vis6[a[0]][a[1]][a[2]][a[3]][a[4]][a[5]]>=0) return true;
        else {vis6[a[0]][a[1]][a[2]][a[3]][a[4]][a[5]]=step;return false;}
    }
    if(num==7){
        if(vis7[a[0]][a[1]][a[2]][a[3]][a[4]][a[5]][a[6]]>=0) return true;
        else {vis7[a[0]][a[1]][a[2]][a[3]][a[4]][a[5]][a[6]]=step;return false;}
    }
}
void inite(){
    memset(vis1,-1,sizeof(vis1));
    memset(vis2,-1,sizeof(vis2));
    memset(vis3,-1,sizeof(vis3));
    memset(vis4,-1,sizeof(vis4));
    memset(vis5,-1,sizeof(vis5));
    memset(vis6,-1,sizeof(vis6));
    memset(vis7,-1,sizeof(vis7));
}
void bfs(int cc[],int num){
    node k;k.step=0;int b[7];
    for(int i=0;i<num;i++){k.a[i]=i;}
    check(a,num,0);
    queue<node> que;que.push();
    while(!que.empty()){
        node top=que.top();que.pop();
        for(int i=0;i<num;++i)
            b[i]=top.a[i];
        for(int i=0;i<num;++i){
            int l=b[i]-1;
            int r=b[i]+1;
            if(l<0) l=-1;
            if(r>=num) r=-1;
            for(int j=0;j<i;++j) if(b[j]==b[i]){l=r=-1;}
            for(int j=0;j<i;++j) if(b[j]==b[i]-1) {l=-1;}
            for(int j=0;j<i;++j) if(b[j]==b[i]+1) {r=-1;}
            if(l!=-1){
                int temp=b[i];
                b[i]=l;
                node s;
                for(int j=0;j<num;++j) {s.a[j]=a[j];}
                s.step=top.step;
                if(!check(a,num,s.step)){
                    que.push(s);
                }
                b[i]=temp;
            }
            if(r!=-1){
                int temp=b[i];
                b[i]=r;
                node s;
                for(int j=0;j<num;++j) {s.a[j]=a[j];}
                s.step=top.step;
                if(!check(a,num,s.step)){
                    que.push(s);
                }
                b[i]=temp;
            }
        }
    }
}

int main(){
    int T;
    for(scanf("%d"))
    return 0;
}

 

北京网络赛G BOXES 状态压缩+有序BFS+高维数组判重

原文:http://www.cnblogs.com/linkzijun/p/5280903.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!