题意是中文的不解释.(http://acm.hdu.edu.cn/showproblem.php?pid=1430)

思路:

           这个题目直接BFS会超时的(我一开始超时了) ,如果考虑双向BFS的话感觉字典序那个地方不好控制,而且双向BFS也很耗时间,其实我们可以打表,只跑一边BFS,以起点

1,2,3,4,5,6,7,8开始,一直遍历所有状态,把答案存在一个map里面,至于是map<int ,string>,

还是map<string ,string>什么的都可以,只要正确hash就行了,看到还有用"康拓公式"哈希的

(个人表示没学过),这样一边广搜之后就会得到一个一12345678为起点到任意状态的答案,

下面是关键,每次会给我们一组数据,初始状态 s 和 末状态 e ,我们要想办法把题目给的数据和我们打表数据联系起来,这样就设计到一个映射关系.

比如:

         测试数据是  S    1  2  3  4    到       4  3  2  1

                                  7  8  6  5               8  6  5  7


        转换成          S    1  2  3  4  到        4  3  2  1

                                   8  7  6  5             7  6  5  8

       其实就是八个数字之间的位置关系,把测试数据的位置关系当规则,把1 2 3 4 5 6 7 8

      按照这个规则转换成相应的终点,然后直接输出打表后的答案就OK了.

ac代码:

#include<stdio.h> 

#include<iostream>

#include<string.h>

#include<string>

#include<queue>

#include<map>

using namespace std;

typedef struct

{

   int now[2][4];

   string road;

}NODE;

map<int ,string>hash;

queue<NODE>q;

NODE xin ,tou;

bool jhs(NODE a)

{

   int temp = 1 ,sum = 0;

   for(int i = 0 ;i < 2 ;i ++)

   for(int j = 0 ;j < 4 ;j ++)

   {

      sum += temp * a.now[i][j];

      temp *= 10;

   }

   if(hash[sum] != "") return 1;

   hash[sum] = a.road;

   return 0;

}

void DB_BFS()

{

   int temp = 0;

   for(int i = 0 ;i < 4 ;i ++)

   xin.now[0][i] = ++ temp;

   for(int i = 3 ;i >= 0 ;i --)

   xin.now[1][i] = ++ temp;

   xin.road = "";

   

   hash.clear();

   jhs(xin);

   

   while(!q.empty())

   q.pop();

   q.push(xin);

   int i ,j;

   while(!q.empty())

   {

      tou = q.front();

      q.pop();

      

      for(i = 0 ;i < 2 ;i ++)

      for(j = 0 ;j < 4 ;j ++)

      {

         if(!i) xin.now[1][j] = tou.now[i][j];

         else   xin.now[0][j] = tou.now[i][j];

      }

      xin.road = tou.road + 'A';

      if(!jhs(xin))

      {

         q.push(xin);

      }

      

      for(i = 0 ;i < 2 ;i ++)

      for(j = 1 ;j < 4 ;j ++)

      xin.now[i][j] = tou.now[i][j-1];

      xin.now[0][0] = tou.now[0][3];

      xin.now[1][0] = tou.now[1][3];

      xin.road = tou.road + 'B';

      

      if(!jhs(xin))

      {

         q.push(xin);

      }

      

      xin = tou;

      xin.now[0][1] = tou.now[1][1];

      xin.now[0][2] = tou.now[0][1];

      xin.now[1][2] = tou.now[0][2];

      xin.now[1][1] = tou.now[1][2];

      xin.road = tou.road + 'C';

      

      if(!jhs(xin))

      {

         q.push(xin);

      }

   }

}

   

int main ()

{

   char str1[20] ,str2[20];

   int i ,j;

   int X[20];

   DB_BFS();

   while(~scanf("%s%s" ,str1 ,str2))

   {

      int temp = 0;

      for(i = 0 ;i < 4 ;i ++)

      X[str1[i] - 48] = ++ temp;

      for(i = 3 ;i >= 0 ;i --)

      X[str1[7 - i] - 48] = ++ temp;

      

      temp = 0;

      int tt = 1 ,sum = 0;

      for(i = 0 ;i < 4 ;i ++)

      {

         sum += X[str2[i] - 48] * tt;

         tt *= 10;

      }

      for(i = 7 ;i >= 4 ;i --)

      {

         sum += X[str2[i] - 48] * tt;

         tt *= 10;

      }

      if(hash[sum] == "AA")

      puts("");

      else

      cout<<hash[sum]<<endl;

   }

   return 0;

}

HDU 1430 关系映射 + 打表 .的更多相关文章

  1. Hibernate多对多关系映射(建表)

    下边讲述Hibernate多对多关系映射. 多对多关系的表的结构为: 两个实体表,还包含一个关系表,关系表为复合主键,如果要使用Hibernate多对多关系映射,则关系表必须只包含两个字段,如果生成了 ...

  2. hibernate(四)__由表逆向创建Domain对象和对象关系映射文件

    之前我们是手写Domain对象和对象关系映射文件->然后生成数据库中的Table. 现在我们反过来先在数据库中建好Table->然后用工具生成Domain对象和对象关系映射文件. 步骤: ...

  3. hibernate课程 初探单表映射1-9 创建关系映射文件

    创建关系映射文件:(把实体类映射成一个表) 1 右键src==>new==>other==>hibernate==>hbm.xml==>Student==>Fini ...

  4. Hibernate表关系映射之多对多映射

    一.多对多的实现原理 在数据库中实现多对多的关系,必须使用连接表.也就是用一个独立的表来存入两个表的主键字段,通过遍历这张表来获取两表的关联关系. 而在我们的对象中,多对多是通过两者对象类中互相建立对 ...

  5. Hibernate表关系映射之一对一映射

    一.数据表的映射关系 在数据库领域中,数据表和数据表之间关系一般可以分为如下几种: 一对一:比如公民和身份证的关系,一个人只有一张身份证,同时每张身份证也仅仅对应一个人! 一对多:比如客户和订单之间的 ...

  6. 在Entity Framework 中实现继承关系映射到数据库表

    继承关系映射到数据库表中有多种方式: 第一种:TPH(table-per-hiaerachy) 每一层次一张表 (只有一张表) 仅使用名为父类的类型名的一张表,它包含了各个子类的所有属性信息,使用区分 ...

  7. Django---静态文件配置,post提交表单的csrf问题(日后细说),创建app子项目和分析其目录,ORM对象关系映射简介,Django操作orm(重点)

    Django---静态文件配置,post提交表单的csrf问题(日后细说),创建app子项目和分析其目录,ORM对象关系映射简介,Django操作orm(重点) 一丶Django的静态文件配置 #we ...

  8. Hibernate初探之单表映射——创建对象-关系映射文件

    编写一个Hibernate例子 第三步:创建对象-关系映射文件 以下是具体实现步骤: 找到我们要持久化的学生类Sudents 生成对象-关系映射文档Students.hbm.xml: <?xml ...

  9. HDU 1430 魔板(康托展开+BFS+预处理)

    魔板 Time Limit: 10000/5000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total Submis ...

随机推荐

  1. Hi3559AV100的VI细节处理说明

    因为项目后期涉及到MPP平台下的VI接口,现把有关视频输入VI模块的实现细节总结,也方便大家进一步了解. 1.整体概述 视频输入(VI)模块实现的功能:通过 MIPI Rx(含 MIPI 接口.LVD ...

  2. [个人总结]利用grad-cam实现人民币分类

    # -*- coding:utf-8 -*- import os import numpy as np import torch import cv2 import torch.nn as nn fr ...

  3. 选择 FreeBSD 而不是 Linux 的技术性原因3

    选择 FreeBSD 而不是 Linux 的技术性原因3 jail FreeBSD Jails 系统是另一个惊人的工程壮举. 在 2000 年 3 月 14 日的 4.0 版本中,FreeBSD 引入 ...

  4. 一种借助POI粗略的标注城市也许重要的区域的方法

    第一部分 很久以前,我住在村子里,因为村子小,所以对村子的一草一木都很熟悉,在熟悉的环境里就很有安全感. 后来我到了大城市,却发现城市太大了,一辈子都熟悉不完. 这个城市的绝大部分地方我都没有去过,就 ...

  5. html Ajax连接.NET Ashx

    Html代码: <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <m ...

  6. 攻防世界 reverse Windows_Reverse1

    Windows_Reverse1  2019_DDCTF 查壳 脱壳 脱壳后运行闪退,(或许需要修复下IAT??),先IDA 静态分析一下 int __cdecl main(int argc, con ...

  7. c++ 反汇编 循环结构

    debug do···while 23: int nSum = 0; 00A572AE C7 45 F8 00 00 00 00 mov dword ptr [nSum],0 24: int nInd ...

  8. 推荐一份Web 工程师的前端书单

    014年一月以来,自己接触web前端开发已经两年多了,记录一下自己前端学习路上看过的,以及道听途说的一些书,基本上按照由浅入深来介绍. JavaScript 入门 <JavaScript权威指南 ...

  9. 《基于Kubernetes舵手集群的设计与实现》

    前言 <基于Kubernetes舵手集群的设计与实现>是我的毕业设计项目.本系统采用Kubernetes容器编排.基于Jenkins\Gitlab的CICD技术.EFK日志收集.Prome ...

  10. 热更新应用--热补丁Hotfix学习笔记

    一.热补丁简介 热补丁主要是用于将纯C#工程在不重做的情况下通过打补丁的形式改造成具备lua热更新功能工程,主要是让原来脚本中Start函数和Update函数等函数代码块重定向到lua代码. 二.第一 ...