首页 > 其他 > 详细

洛谷P1379 八数码难题

时间:2019-10-27 01:04:41      阅读:93      评论:0      收藏:0      [点我收藏+]

https://www.luogu.org/problem/P1379

这个代码需要用c++11提交。

#include<bits/stdc++.h>
#include<unordered_map>
using namespace std;

string st;
int dx[]={0,0,1,-1},dy[]={1,-1,0,0};
int bfs(){
    string ed="123804765";

    queue<string> q;
    unordered_map<string,int> d;

    q.push(st);
    d[st]=0;

    while(!q.empty()){
        string t=q.front();
        q.pop();

        if(t==ed) return d[t];

        int distance=d[t];
        int k=t.find(0);
        int x=k/3,y=k%3;
        for(int i=0;i<4;i++){
            int a=x+dx[i],b=y+dy[i];

            if(a>=0&&a<3&&b>=0&&b<3){
                swap(t[a*3+b],t[k]);
                if(!d.count(t)){
                    q.push(t);
                    d[t]=distance+1;
                }
                swap(t[a*3+b],t[k]);
            }

        }
    }
    return -1;
}

int main(){

    for(int i=0;i<9;i++){
        char c;
        cin>>c;
        st+=c;
    }
    cout<<bfs()<<endl;
}

 

洛谷P1379 八数码难题

原文:https://www.cnblogs.com/QingyuYYYYY/p/11746311.html

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