三个水杯——java,广度优先搜索
题目如下:
21-三个水杯
内存限制:64MB 时间限制:1000ms 特判: No
通过数:51 提交数:137 难度:4
题目描述:
输入描述:
第一行一个整数N(0<N<50)表示N组测试数据
接下来每组测试数据有两行,第一行给出三个整数V1 V2 V3 (V1>V2>V3 V1<100 V3>0)表示三个水杯的体积。
第二行给出三个整数E1 E2 E3 (体积小于等于相应水杯体积)表示我们需要的最终状态
输出描述:
每行输出相应测试数据最少的倒水次数。如果达不到目标状态输出-1
样例输入:
2
6 3 1
4 1 1
9 3 2
7 1 1
样例输出:
3
-1
解题思想:题目不难,主要是捉住关键点就容易了,看到最少的倒水次数,必然和广度优先搜索有联系,其实就是一颗六叉树。
每个杯子都可以往其他两个杯子倒水。可以相互倒水,情况如下:1>2,1>3,2>1,2>3,3>1,3>2;
代码如下:用到了队列+广度的方法。
import java.util.Arrays;
import java.util.LinkedList;
import java.util.Queue;
import java.util.Scanner; class State
{
int glass[] = new int[3];
int step;
}
public class Main
{
static final int MAX = 3;
static int v[] = new int[MAX];
static int e[] = new int[MAX];
static boolean vis[][][] = new boolean[300][300][300];
static int flag;
public static void main(String []args)
{
Scanner cin = new Scanner(System.in);
int N = cin.nextInt();
for(int i = 0; i < N; i++)
{
for(int j = 0; j < 3; j++)
{
v[j] = cin.nextInt();
}
for(int j = 0; j < 3; j++)
{
e[j] = cin.nextInt();
}
flag = 0;
Init();
BFS();
if(flag == 0)
{
System.out.println("-1");
}
}
}
static void Init()
{
for(int i = 0; i < v[0]; i++)
{
for(int j = 0; j < v[0]; j++)
{
for(int k = 0; k < v[0]; k++)
{
vis[i][j][k] = false;
}
}
}
}
static void BFS()
{
State start = new State();
start.glass[0] = v[0];
start.glass[1] = 0;
start.glass[2] = 0;
if(start.glass[0] == e[0] && start.glass[1] == e[1] && start.glass[2] == e[2])
{
flag = 1;
System.out.println("0");
return;
}
Queue <State> que = new LinkedList<State>();
que.add(start);
vis[start.glass[0]][start.glass[1]][start.glass[2]] = true;
while(!que.isEmpty())
{
State temp = new State();
temp = que.poll();
for(int i = 0; i < 3; i++)//核心代码
{
if(temp.glass[i] == 0)
{
continue;
}
//i向j中倒水
for(int j = 0; j < 3; j++)
{
if(j == i || temp.glass[j] == v[j]) //同一个杯子或者这个杯子已经满了
{
continue;
}
//向其他某个杯子倒
State mid = new State();//此处的对象用得很巧妙(不可以定义在这个循环的外面),我之前都是建立一个很大很大的数组用来保存队列,太浪费空间了。
mid.glass[0] = temp.glass[0];
mid.glass[1] = temp.glass[1];
mid.glass[2] = temp.glass[2];
mid.step = temp.step+1;
int rest = v[j]-temp.glass[j];
if(rest <= mid.glass[i])
{
mid.glass[j] = v[j];
mid.glass[i] = mid.glass[i]-rest;
if(vis[mid.glass[0]][mid.glass[1]][mid.glass[2]] == false)
{
if(mid.glass[0] == e[0] && mid.glass[1] == e[1] && mid.glass[2] == e[2])
{
flag = 1;
System.out.println(mid.step);
return;
}
que.add(mid);
vis[mid.glass[0]][mid.glass[1]][mid.glass[2]] = true;
}
}
else
{
mid.glass[j] = mid.glass[j] + mid.glass[i];
mid.glass[i] = 0;
if(vis[mid.glass[0]][mid.glass[1]][mid.glass[2]] == false)
{
if(mid.glass[0] == e[0] && mid.glass[1] == e[1] && mid.glass[2] == e[2])
{
flag = 1;
System.out.println(mid.step);
return;
}
que.add(mid);
vis[mid.glass[0]][mid.glass[1]][mid.glass[2]] = true;
}
}
}
}
}
}
}
三个水杯——java,广度优先搜索的更多相关文章
- BFS(三):双向广度优先搜索
所谓双向广度搜索指的是搜索沿两个方向同时进行:(1)正向搜索:从初始结点向目标结点方向搜索:(2)逆向搜索:从目标结点向初始结点方向搜索:当两个方向的搜索生成同一子结点时终止此搜索过程. 广度双向搜索 ...
- 利用广度优先搜索(BFS)与深度优先搜索(DFS)实现岛屿个数的问题(java)
需要说明一点,要成功运行本贴代码,需要重新复制我第一篇随笔<简单的循环队列>代码(版本有更新). 进入今天的主题. 今天这篇文章主要探讨广度优先搜索(BFS)结合队列和深度优先搜索(DFS ...
- java深度搜索与广度优先搜索
图结构展示: 实现过程: 首先,我们来看看图结构在代码中的实现.有三块逻辑: 1.图中的节点: public class GraphNode { public List<GraphEdge> ...
- 深度优先搜索(DFS)与广度优先搜索(BFS)的Java实现
1.基础部分 在图中实现最基本的操作之一就是搜索从一个指定顶点可以到达哪些顶点,比如从武汉出发的高铁可以到达哪些城市,一些城市可以直达,一些城市不能直达.现在有一份全国高铁模拟图,要从某个城市(顶点) ...
- Java用广度优先搜索快速搜索文件
背景 在开发的过程中,经常需要在文件系统里按某些条件搜索文件,比如音乐播放器扫描音乐,而搜索文件,大多人喜欢用递归的方式,而这也是最容易想到的方式.递归方式如果文件夹很深就容易造成栈溢出,而且不断的压 ...
- Java爬虫搜索原理实现
permike 原文 Java爬虫搜索原理实现 没事做,又研究了一下爬虫搜索,两三天时间总算是把原理闹的差不多了,基本实现了爬虫搜索的原理,本次实现还是俩程序,分别是按广度优先和深度优先完成的,广度优 ...
- nyoj 题目21 三个水杯
三个水杯 时间限制:1000 ms | 内存限制:65535 KB 难度:4 描述 给出三个水杯,大小不一,并且只有最大的水杯的水是装满的,其余两个为空杯子.三个水杯之间相互倒水,并且水杯没有 ...
- Leetcode之广度优先搜索(BFS)专题-详解429. N叉树的层序遍历(N-ary Tree Level Order Traversal)
Leetcode之广度优先搜索(BFS)专题-429. N叉树的层序遍历(N-ary Tree Level Order Traversal) 给定一个 N 叉树,返回其节点值的层序遍历. (即从左到右 ...
- NYOJ 21 三个水杯
三个水杯 时间限制:1000 ms | 内存限制:65535 KB 难度:4 描述 给出三个水杯,大小不一,并且只有最大的水杯的水是装满的,其余两个为空杯子.三个水杯之间相互倒水,并且水杯没有 ...
随机推荐
- laravel----------laravel一些注意事项和一些说明
1.php artisan key:generate 解释:.env文件里面的APP_KEY参数设置为一个随机字符串也就是这个key是一个随机字符串,用于实现框架中的encrypt(加密)服务, ...
- JavaScript命名规范基础及系统注意事项
前端代码中的自定义变量命名 命名方法: 1.驼峰 2.下划线连接 对于文件名,我们一般采用小写字母+下划线的形式 为什么?因为在window下a ...
- zookeeper注册与发现
pom.xml添加如下引用: <dependency> <groupId>org.apache.zookeeper</groupId> <artifactId ...
- Python记录wsgi
类实现wsgi app from wsgiref.util import setup_testing_defaults from wsgiref.simple_server import make_s ...
- mysql数据库设计三范式
为了建立冗余较小.结构合理的数据库,设计数据库时必须遵循一定的规则.在关系型数据库中这种规则就称为范式.范式是符合某一种设计要求的总结.要想设计一个结构合理的关系型数据库,必须满足一定的范式. 在实际 ...
- P1342 请柬
最近一直在做最短路......所以今天就再做一道最短路吧.... 题目描述 在电视时代,没有多少人观看戏剧表演.Malidinesia古董喜剧演员意识到这一事实,他们想宣传剧院,尤其是古色古香的喜剧片 ...
- cocos dos命令
- 关于React Native中FlatList的onEndReached属性频繁调用的一种解决办法
FlatList组件是RN0.43后引入的组件.作为高性能列表组件,FlatList在ListView的基础上优化了加载性能并简化了渲染过程.不仅如此,该组件还提供了onRefresh和onEndRe ...
- react中对于context的理解
一.context旧版的基本使用 1.context的理解 当不想在组件树中通过逐层传递props或state的方式来传递数据时,可使用context来实现跨层级的组件数据传递. 2.context的 ...
- Object.prototype的成员介绍
3.Object.prototype的成员介绍 Object.prototype是js中所有的对象的祖宗 Object.prototype中所有的成员都可以被js中所有的对 ...