传送门

1.先用dfs枚举9!的全排列,存到hash数组里(类似离散化),因为顺序枚举,就不需要排序了

2.朴素bfs,判重就用二分找hash;如果发现当前状态=要求状态,输出步数结束程序

上代码

#include<iostream>
#include<cstdio>
#include<cmath>
#include<cstring>
#include<algorithm>
using namespace std;

; 

long long hash[MAXHASH];
bool hashbook[MAXHASH];
;
];

;

void hinit(long long step,long long val){
    ){
        hn++;
        hash[hn]=val;
        return;
    }
    ;i<=;i++){
        ){
            hinit_book[i]=;
            hinit(step+,val*+i);
            hinit_book[i]=;
        }
    }
}

bool hashput(long long val){
    ,r=hn;
    for(;;){
        if(l==r){
            ){
                hashbook[l]=;
                ;
            }else{
                ;
            }
        }
        ;
        if(val>hash[mid]){
            l=mid+;
        }else{
            r=mid;
        }
    }
}

struct uct1{
    long long data;
    long long pos;
    long long step;
}que[];

long long mywap(long long data,long long pa,long long pb){
    long long ans=data;

    ,-pb+)-data%(,-pb);
    ans-=df;
    ans+=df/pow(,-pb)*pow(,-pa);

    df=data%(,-pa+)-data%(,-pa);
    ans-=df;
    ans+=df/pow(,-pa)*pow(,-pb);
    return ans;
}

,tail=;

int main() {
    hinit(,);
    long long pig;
    cin>>pig;

    int bap=pig;
    if(pig==end){
        cout<<;
        ;
    }
    int pigpos;
    ;bap>;pigpos--){
        ==){
            break;
        }
        bap=bap/;
    }
    ){
        pigpos=;
    }
    head=;
    tail=;
    que[tail].data=pig;
    que[tail].pos=pigpos;
    que[tail].step=;
    tail++;
    for(;head<tail;){
        int tdata;
        int tpos;
        ]={};
        for(;;){
            )%==&&flag[]==){
                tdata=mywap(que[head].data,que[head].pos,que[head].pos+);
                tpos=que[head].pos+;
                flag[]++;
            })%==&&flag[]<){
                ]==){
                    tdata=mywap(que[head].data,que[head].pos,que[head].pos+);
                    tpos=que[head].pos+;
                }else{
                    tdata=mywap(que[head].data,que[head].pos,que[head].pos-);
                    tpos=que[head].pos-;
                }
                flag[]++;
            })%==&&flag[]==){
                tdata=mywap(que[head].data,que[head].pos,que[head].pos-);
                tpos=que[head].pos-;
                flag[]++;
            }&&que[head].pos<=&&flag[]==){
                tdata=mywap(que[head].data,que[head].pos,que[head].pos+);
                tpos=que[head].pos+;
                flag[]++;
            }&&que[head].pos<=&&flag[]<){
                ]==){
                    tdata=mywap(que[head].data,que[head].pos,que[head].pos+);
                    tpos=que[head].pos+;
                }else{
                    tdata=mywap(que[head].data,que[head].pos,que[head].pos-);
                    tpos=que[head].pos-;
                }

                flag[]++;
            }&&que[head].pos<=&&flag[]==){
                tdata=mywap(que[head].data,que[head].pos,que[head].pos-);
                tpos=que[head].pos-;
                flag[]++;
            }else{
                break;
            }
            if(tdata==end){
                cout<<que[head].step+;
                ;
            }
            ){
                que[tail].data=tdata;
                que[tail].pos=tpos;
                que[tail].step=que[head].step+;
                tail++;
            }
        }
        head++;
    }
    ;
}

其实还可以用双向bfs优化,算hash数组可以用康托展开

但懒得写了(逃)

洛谷P1379 八数码难题的更多相关文章

  1. 洛谷 P1379 八数码难题 解题报告

    P1379 八数码难题 题目描述 在3×3的棋盘上,摆有八个棋子,每个棋子上标有1至8的某一数字.棋盘中留有一个空格,空格用0来表示.空格周围的棋子可以移到空格中.要求解的问题是:给出一种初始布局(初 ...

  2. 洛谷——P1379 八数码难题

    P1379 八数码难题 双向BFS 原来双向BFS是这样的:终止状态与起始状态同时入队,进行搜索,只不过状态标记不一样而已,本题状态使用map来存储 #include<iostream> ...

  3. 洛谷P1379八数码难题

    题目描述 在3×3的棋盘上,摆有八个棋子,每个棋子上标有1至8的某一数字.棋盘中留有一个空格,空格用0来表示.空格周围的棋子可以移到空格中. 要求解的问题是:给出一种初始布局(初始状态)和目标布局(为 ...

  4. 洛谷 P1379 八数码难题 Label:判重&&bfs

    特别声明:紫书上抄来的代码,详见P198 题目描述 在3×3的棋盘上,摆有八个棋子,每个棋子上标有1至8的某一数字.棋盘中留有一个空格,空格用0来表示.空格周围的棋子可以移到空格中.要求解的问题是:给 ...

  5. 洛谷 P1379 八数码难题

    题目描述 在3×3的棋盘上,摆有八个棋子,每个棋子上标有1至8的某一数字.棋盘中留有一个空格,空格用0来表示.空格周围的棋子可以移到空格中.要求解的问题是:给出一种初始布局(初始状态)和目标布局(为了 ...

  6. 洛谷 - P1379 - 八数码难题 - bfs

    https://www.luogu.org/problemnew/show/P1379 #include <bits/stdc++.h> using namespace std; #def ...

  7. 洛谷—— P1379 八数码难题

    https://daniu.luogu.org/problem/show?pid=1379 题目描述 在3×3的棋盘上,摆有八个棋子,每个棋子上标有1至8的某一数字.棋盘中留有一个空格,空格用0来表示 ...

  8. 洛谷 P1379 八数码难题 题解

    我个人感觉就是一道bfs的变形,还是对bfs掌握不好的人有一定难度. 本题思路: 大体上用bfs搜,用map来去重,在这里只需要一个队列,因为需要较少步数达到的状态一定在步数较多的状态之前入队列. # ...

  9. 洛谷 P1379 八数码难题(map && 双向bfs)

    题目传送门 解题思路: 一道bfs,本题最难的一点就是如何储存已经被访问过的状态,如果直接开一个bool数组,空间肯定会炸,所以我们要用另一个数据结构存,STL大法好,用map来存,直接AC. AC代 ...

随机推荐

  1. CF209C Trails and Glades

    题目链接 题意 有一个\(n\)个点\(m\)条边的无向图(可能有重边和自环)(不一定联通).问最少添加多少条边,使得可以从\(1\)号点出发,沿着每条边走一遍之后回到\(1\)号点. 思路 其实就是 ...

  2. Luogu P3227 [HNOI2013]切糕 最小割

    首先推荐一个写的很好的题解,个人水平有限只能写流水账,还请见谅. 经典的最小割模型,很多人都说这个题是水题,但我还是被卡了=_= 技巧:加边表示限制 在没有距离\(<=d\)的限制时候,我们对每 ...

  3. JDBC Template

    JDBC Template 1. Spring JDBC Spring框架对JDBC的简单封装,提供了一个JDBCTemplate对象用来简化JDBC的开发 步骤: 导入jar包 创建JDBCTemp ...

  4. Spark 用户自定义函数 Java 示例

    Spark UDF Java 示例 在这篇文章中提到了用Spark做用户昵称文本聚类分析,聚类需要选定K个中心点,然后迭代计算其他样本点到中心点的距离.由于中文文字分词之后(n-gram)再加上昵称允 ...

  5. EffectiveC++ 第2章 构造/析构/赋值运算

    我根据自己的理解,对原文的精华部分进行了提炼,并在一些难以理解的地方加上了自己的"可能比较准确"的「翻译」. Chapter 2 构造 / 析构 / 赋值 条款 05:了解C++ ...

  6. java8 list和map的forEach

    list forEach示例 public class HelloWorld { public static void main(String[] args) { List<User> l ...

  7. Pandas时间处理的一些小方法

    一.以下有两种方式可以创建一个Timestamp对象: 1. Timestamp()的构造方法 import pandas as pd from datetime import datetime as ...

  8. 1.在虚拟机中安装Linux中的CentOS7系统

    1. 虚拟机的创建:如下图,可在右侧窗口中创建新的虚拟机,也可以在文件菜单中新建虚拟机,或者使用快捷键新建 这里选择“自定义(高级) ”,然后进入“下一步”设置 这里是选择虚拟机硬件的美容性的,默认就 ...

  9. MySql的事务控制(TCL语言)

    ⒈事务 一个或一组sql语句组成一个执行单元,这个执行单元要么全部执行,要么全部不执行. ⒉事务的特性(ACID) 1.原子性(Atomicity):一个事务不可再分割,要么都执行要么都不执行. 2. ...

  10. Python爬虫基础之认识爬虫

    一.前言 爬虫Spider什么的,老早就听别人说过,感觉挺高大上的东西,爬网页,爬链接~~~dos黑屏的数据刷刷刷不断地往上冒,看着就爽,漂亮的校花照片,音乐网站的歌曲,笑话.段子应有尽有,全部都过来 ...