2014 网选 5012 Dice(bfs模板)

  1 /*
  2     题意:就是给定两个筛子,每个筛子上6个面,每个面的数字属于[1,6], 且互不相同!
  3     问a筛子最少经过按照题目规定的要求转动,达到和b筛子上下左右前后的数字相同!
  4     
  5     思路:很直白的bfs,将每一种状态对应一个数字,保证这种状态不会重新加入队列中! 
  6 */
  7 #include<iostream>
  8 #include<cstdio>
  9 #include<cstring>
 10 #include<algorithm>
 11 #include<queue>
 12 using namespace std;
 13 
 14 int a[7], ss;
 15 int vis[654330];
 16 
 17 struct node{
 18     int k[7];
 19     node(){}
 20     node(int a1, int a2, int a3, int a4, int a5, int a6){
 21         k[1]=a1;
 22         k[2]=a2;
 23         k[3]=a3;
 24         k[4]=a4;
 25         k[5]=a5;
 26         k[6]=a6;
 27     }
 28     int step;
 29 };
 30 
 31 queue<node>q; 
 32 
 33 
 34 int sum(node x){
 35     int s=0;
 36     for(int i=1; i<=6; ++i)
 37        s= s*10 + x.k[i];
 38     return s;
 39 }
 40 
 41 bool bfs(){
 42     while(!q.empty()) q.pop();
 43     node cur(a[1], a[2], a[3], a[4], a[5], a[6]);
 44     cur.step=0;
 45     q.push(cur);
 46     vis[sum(cur)]=1;
 47     while(!q.empty()){
 48         cur = q.front();
 49         if(sum(cur)==ss){
 50             printf("%d\n", cur.step);
 51             return true;
 52         }
 53         q.pop();
 54         node *nt = new node(cur.k[5], cur.k[6], cur.k[3], cur.k[4], cur.k[2], cur.k[1]);
 55         int v = sum(*nt);
 56         if(!vis[v]){
 57             vis[v]=1;
 58             nt->step = cur.step + 1; 
 59             q.push(*nt);
 60         }
 61         
 62         nt = new node(cur.k[6], cur.k[5], cur.k[3], cur.k[4], cur.k[1], cur.k[2]);
 63         v = sum(*nt);
 64         if(!vis[v]){
 65             vis[v]=1;
 66             nt->step = cur.step + 1; 
 67             q.push(*nt);
 68         }
 69         
 70         nt = new node(cur.k[3], cur.k[4], cur.k[2], cur.k[1], cur.k[5], cur.k[6]);
 71         v = sum(*nt);
 72         if(!vis[v]){
 73             vis[v]=1;
 74             nt->step = cur.step + 1; 
 75             q.push(*nt);
 76         }
 77         
 78         nt = new node(cur.k[4], cur.k[3], cur.k[1], cur.k[2], cur.k[5], cur.k[6]);
 79         v = sum(*nt);
 80         if(!vis[v]){
 81             vis[v]=1;
 82             nt->step = cur.step + 1; 
 83             q.push(*nt);
 84         }
 85     }
 86     return false;
 87 }
 88 
 89 int main(){
 90     while(scanf("%d%d%d%d%d%d", &a[1], &a[2], &a[3], &a[4], &a[5], &a[6])!=EOF){
 91         ss=0;
 92         for(int i=1; i<=6; ++i){
 93             int x;
 94             scanf("%d", &x);
 95             ss = ss * 10 + x;
 96         }
 97         memset(vis, 0, sizeof(vis));
 98         if(!bfs())
 99             printf("-1\n"); 
100     }
101     return 0;
102 }

 

转载于:https://www.cnblogs.com/hujunzheng/p/3975625.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/531660.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

matlab 神经网络dpi,基于DPI和BP神经网络的P2P流量识别研究

研究与开发 现代计算机 2019.04 上 文章编号&#xff1a;1007-1423(2019)10-0031-05 DOI&#xff1a;10.3969/j.issn.1007-1423.2019.10.007 基于 DPI 和 BP 神经网络的 P2P 流量识别研究 万建伟&#xff0c;胡勇 (四川大学电子信息学院&#xff0c;成都 610021) 摘要&#xff…

2014 网选 5011 Game(Nim游戏,数学题)

/*题意&#xff1a;Nim游戏&#xff01; 思路&#xff1a;通过异或&#xff0c;判断将n个数表示成二进制的形式之后&#xff0c;是否对应位的数字1 的个数是偶数&#xff01; */ #include<iostream> using namespace std;int main(){int n, x, s;while(cin>>n){s…

汉诺塔实践python,Python练习题11:汉诺塔实践

在终端输出如下信息--python在终端输出如下信息--python ???????????????????????????????????????????????????????????????????????????????????????????????? 描述 练习一…

oracle授权只读用户,Oracle创建只读用户(账号)的方法

第一步&#xff1a;创建用户(需要使用有dba管理员权限的用户创建一个新的用户&#xff0c;比如system)create user 用户名 identified by 密码 default tablespace 表空间;第二步&#xff1a;赋连接权限grant connect to 用户名;grant Resource to 用户名;权限分类&#xff1a;…

java中图片文件的传输及显示(Socket以及ServerSocket演示)

//客户端部分 package testSix;import java.awt.Graphics; import java.io.IOException; import java.io.InputStream; import java.io.OutputStream; import java.net.InetAddress; import java.net.Socket; import java.util.Iterator;import javax.imageio.ImageIO; import …

oracle 表约束非空,oracle--约束(主键、非空、检查)

问题1:学号重复了&#xff0c;数据还可以插入成功使用主键约束&#xff1a;学号是唯一标识一条数据的&#xff0c;所以必须唯一且不能为空---(1)、在确定为主键的字段后添加 primary key关键字---(2)、在创建表的后面使用&#xff1a;constraints pk_表名_字段名 primary key(字…

先序,中序,后序线索二叉树

//后序线索&#xff0c;这种方法不容易想到 1 #include<iostream>2 #include<cstring>3 #include<cstdio>4 #include<algorithm>5 6 using namespace std;7 8 struct TREE{9 int val; 10 TREE *ch[2]; 11 TREE *thread;//该节点的线索的…

cdp备份适合oracle吗,备份系统建设中的四个认识误区,你有吗?

【摘要】本文总结了企业在备份建设中常见的四个认识误区。【作者】李志刚企业在备份建设中&#xff0c;主要的认识误区有以下几个&#xff1a;一、用双机、阵列复制等系统冗余替代数据备份双机双柜可实现服务器和存储的高可用性&#xff0c;保障业务持续运行&#xff0c;但绝不…

2014 网选 广州赛区 hdu 5023 A Corrupt Mayor's Performance Art

1 #include<iostream>2 #include<cstring>3 #include<cstdio>4 #include<algorithm>5 #define N 10000056 using namespace std;7 8 int c[35];9 int tree[N*4];//正值表示该节点所管理的区间的颜色是纯色&#xff0c;-1表示的是非纯色 10 int n, m; …

oracle的todate函数 不用英文,关于在mybaties 和 oracle的to_date函数的问题?

ITMISSD)TO_DATE使用详解时常使用to_date函数来查询特定时间内的数据。语法&#xff1a;TO_DATE(x [, format])用于将字符串x转换为时间值&#xff0c;该函数可以指定一个可选的字符串format参数来说明x的格式。如果没有指定format参数&#xff0c;日期就使用默认的数据库格式(…

2014 网选 广州赛区 hdu 5025 Saving Tang Monk(bfs+四维数组记录状态)

1 /*2 这是我做过的一道新类型的搜索题&#xff01;从来没想过用四维数组记录状态&#xff01;3 以前做过的都是用二维的&#xff01;自己的四维还是太狭隘了.....4 5 题意&#xff1a;悟空救师傅 &#xff01; 在救师父之前要先把所有的钥匙找到&#xff01;6…

oracle move 换用户,Oracle move方法释放delete后的表空间

在新增记录时,高水位线会慢慢往上移,但是在删除记录后,高水位线却不会往下移。在使用delete from命令删除大量数据时会导致因HWM引起的性能问题。删除高水位的最直接的方法是truncate Table。-----Oracle 频繁delete表空间无法释放&#xff0c;释放表空间方法&#xff0c;清除…

oracle 字段除以1000,ORACLE常用}1000(之一)_oracle

大家在oracle的r候可能龅胶芏嗫雌聿浑y的}, 特eπ率碚f, 今天我伟阉Y一下, l布o大家, 希望Υ蠹矣助! 和大家一起探, 共同M步!     ORACLE高手碚f是不用看的. 1. Oracle安b完成后的初始口令?   internal/oracle   sys/change_on_install   system/manager   scott/…

java中图片文件的判断

javax.imageio 类 ImageIO BufferedImage bi ImageIO.read(resFile);//resFile --- InputStreamif(bi null){ System.out.println(此文件不为图片文件); }try {//判断是否为图片文件并且返回图片的格式&#xff01;ImageInputStream iis ImageIO.createImageInputStream(o)…

oracle 查看数据库性能,oracle 11G使用statspack查看数据库的性能

1.安装Statspack工具(statspack工具的脚本在$ORACLE_HOME/rdbms/admin目录下,全是以sp开头的文件)[oracleoracle ~]$ sqlplus / as sysdbasql> select file_name,tablespace_name from dba_data_files;FILE_NAMETABLESPACE_NAME-------------------------------------------…

java中JTextPane使输出字符到指定的宽度换行,并将垂直滚动条的位置移动到输出的最后位置...

SimpleAttributeSet set new SimpleAttributeSet();Document doc tp.getStyledDocument(); FontMetrics fm tp.getFontMetrics(tp.getFont());//得到JTextPane 的当前字体尺寸int paneWidth tp.getWidth();//面板的宽度String text new String(bt, 0, len);  try{for(int…

oracle 10g rac 修改sga_target不生效,Oracle Rac 修改SGA_TARGET值无变化

Oracle Rac 修改SGA_TARGET值无变化发布时间&#xff1a;2020-08-13 23:02:13来源&#xff1a;ITPUB博客阅读&#xff1a;93作者&#xff1a;dmcatding系统&#xff1a;Red Hat Enterprise Linux Server release 6.4 (Santiago)数据库&#xff1a;Oracle 11.2.0.4.1710171、 al…

codeforces George and Job

1 /*2 题意&#xff1a;给一个长度为n的序列&#xff0c; 从中选择长度为m的k个区间&#xff08;任意两个区间不会有公共部分&#xff09;3 使得所选择的区间的和最大&#xff01;4 思路&#xff1a;这是一种很常见的dp5 6 dp[i][j] 表示的是前 i 个数选择…

oracle表空间 设置,Oracle表空间怎么设置和管理

前言表空间是 Oracle 特有的一种逻辑结构&#xff0c;是管理和组织 Oracle 数据文件一种方式&#xff0c;一个Oracle 数据库能够有一个或多个表空间&#xff0c;而一个表空间则对应一个或多个物理的数据库文件。Oracle 的表空间分为永久空间和临时表空间&#xff0c;同时又分为…

2014 网选 5024 Wang Xifeng's Little Plot

题意&#xff1a;从任意一个任意一个可走的点开始找一个最长的路&#xff0c;这条路如果有转弯的话&#xff0c; 那么必须是 90度&#xff0c;或者没有转弯&#xff01; 思路&#xff1a; 首先用dfs将所有可走点开始的 8 个方向上的线段的最长长度求出来 &#xff01; step[i][…