三个水杯——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 描述 给出三个水杯,大小不一,并且只有最大的水杯的水是装满的,其余两个为空杯子.三个水杯之间相互倒水,并且水杯没有 ...
随机推荐
- 北京大学Cousera学习笔记--1-学习规划
1.计算机导论与C语言基础 1>.计算导论:计算机的基本原理.计算机的发展趋势.程序运行的基本原理 2>.C程序设计:感性认识C程序.理性认识C程序:机构化的程序-函数.更多的数据结构 2 ...
- Linux系统——MHA-Atlas-MySQL高可用集群
Linux系统——MHA-Atlas-MySQL高可用集群 MHA MHA介绍MHA(Master High Availability)目前在MySQL高可用方面是一个相对成熟的解决方案,是一套优秀的 ...
- ubuntu16.04利用deb包安装mysql
https://blog.csdn.net/zht741322694/article/details/79013093
- 福州大学软件工程1916|W班 第5次作业成绩排名
1. 作业链接: https://edu.cnblogs.com/campus/fzu/SoftwareEngineering1916W/homework/2768 2. 评分准则: 本次作业评分分为 ...
- redis的 rdb 和 aof 持久化的区别
aof,rdb是两种 redis持久化的机制.用于crash后,redis的恢复. rdb的特性如下: Code: fork一个进程,遍历hash table,利用copy on write,把整个d ...
- Dubbo 泛化调用的参数解析问题及一个强大的参数解析工具 PojoUtils
排查了3个多小时,因为一个简单的错误,发现一个强大的参数解析工具,记录一下. 背景 Nodejs 通过 tether 调用 Java Dubbo 服务.请求类的某个参数对象 EsCondition 有 ...
- 1344:【例4-4】最小花费 dijkstra
1344:[例4-4]最小花费 Dijkstra (1)a [ i ] [ j ] 存转账率(..转后所得率..) (2)dis [ i ] 也就是 a [ 起点 ] [ i ] (3)f [ i ] ...
- quill富文本编辑器 API
//1. 从第三个开始删除,删除4个 // console.log(this.quill.deleteText(2, 4)); // 12345678 1278 // 2.(返回对象)返回从第三个开始 ...
- context使用
1. 概述 go语言中goroutine之间的关联关系,缺乏维护,在erlang中有专门的机制来保障新开协程的生命周期,在go语言中,只能通过channel + select来实现,但不够直观,很绕. ...
- java.lang.IllegalStateException: getWriter() has already been called for this response
出现此异常的三种可能: 1.通过response.reset(); 刷新可能存在一些未关闭的getWriter(). 来源:http://blog.csdn.net/wonder4/article/ ...