题意:

给你三个杯子,a,b,c,没有刻度,刚开始c杯是满的,倒水的要求,要么倒出水的杯子倒空,要么倒入杯子倒满.

结果:

要求某个杯子内有d水量,并且倒出的水量最少,如果倒不出d水量,那么倒出d1(d1<d)水量,并且倒出的水量最少

解题思路:

总的水量为c,只要知道前俩个杯子的水量,那么第三个杯子的水量就确定了,所以,状态数最大只有a * b种,所以一个二维数组标记状态就够.

要求倒出的水量最少,那么使用优先队列,按照倒出的水量最少开始搜索.

初始化结点为(0,0,c),由这个结点开始往外扩展,此时倒出的水量为0,结果d为0,注意代码内有个特判,如果d >= c,那么最大的d就是c,倒出的水量为0

#include <iostream>
#include <stdio.h>
#include <memory.h>
#include <queue> using namespace std;
const int NN = 201;
int a[3];
int d;
int maxD = -1;
int maxNum = 0;
//记录c1,c2,已知c1,c2,c3就可以确定
int vis[NN][NN];
class State
{
public:
int a[3];
int waterNum;
State()
: waterNum(0)
{
a[0] = 0;
a[1] = 0;
a[2] = 0;
}
State(int d1, int d2, int d3, int w)
: waterNum(w)
{
a[0] = d1;
a[1] = d2;
a[2] = d3;
}
bool operator ()(State& a, State& b)
{
return a.waterNum > b.waterNum;
}
};
priority_queue<State, vector<State>, State> q;
void bfs()
{
while (!q.empty())
{
State s = q.top();
q.pop();
for(int i = 0; i < 3; i++)
for(int j = 0; j < 3; j++)
{
if(i == j || s.a[i] == 0)
continue;
//把水从i导入j中
//要么i倒空,要么j倒满
int dj = a[j] - s.a[j];
if(dj == 0)
//j是满的,不能倒
continue;
//i杯内的水量
int di = s.a[i];
//倒出的水量
State ss(s.a[0], s.a[1], s.a[2], s.waterNum);
if(dj > di)
{
//i杯倒空
ss.waterNum = ss.waterNum + di;
ss.a[i] = 0;
ss.a[j] = ss.a[j] + di;
}
else
{
//j杯倒满
ss.waterNum = ss.waterNum + dj;
ss.a[i] = di - dj;
ss.a[j] = ss.a[j] + dj;
}
if(vis[ss.a[0]][ss.a[1]])
continue;
//判断当前状态
if(ss.a[i] <= d && ss.a[i] > maxD)
{
maxD = ss.a[i];
maxNum = ss.waterNum;
}
if(ss.a[j] <= d && ss.a[j] > maxD)
{
maxD = ss.a[j];
maxNum = ss.waterNum;
}
if(maxD == d)
return;
q.push(ss);
vis[ss.a[0]][ss.a[1]] = 1;
}
}
}
void clear()
{
while (!q.empty())
q.pop();
memset(vis, 0, sizeof(vis));
maxNum = 0;
maxD = 0;
}
int main()
{
int num;
cin >> num;
while (num--)
{
clear();
cin >> a[0] >> a[1] >> a[2] >> d;
if(d >= a[2])
{
cout << 0 << " " << a[2] << endl;
continue;
}
State state(0, 0, a[2], 0);
q.push(state);
vis[0][0] = 1;
bfs();
if(maxD == 0)
cout << 0 << " " << 0 << endl;
else
cout << maxNum << " " << maxD << endl;
}
return 0;
}

  

uva10603-倒水问题-暴力枚举-隐式图搜索的更多相关文章

  1. uva-321-暴力枚举-隐式图搜索

    题意:给你n个房间,有许多灯的控制开关,i房间灯的开关在j房间,未开灯的房间不能进,i房间和j房间之间如果没有门,也不能从i进入到j,开始房间是1,并且灯是开着的,问你是否能够走到最后一个房间n,并且 ...

  2. UVa 658 - It's not a Bug, it's a Feature!(Dijkstra + 隐式图搜索)

    链接: https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem& ...

  3. 紫书 例题 11-6 UVa 658 (状态压缩+隐式图搜索+最短路)

    这道题用到了很多知识点, 是一道好题目.      第一用了状态压缩, 因为这里最多只有20位, 所以可以用二进制来储存状态 (要对数据范围敏感), 然后 涉及到了一些位运算.     第二这里是隐式 ...

  4. 【uva 658】It's not a Bug, it's a Feature!(图论--Dijkstra或spfa算法+二进制表示+类“隐式图搜索”)

    题意:有N个潜在的bug和m个补丁,每个补丁用长为N的字符串表示.首先输入bug数目以及补丁数目.然后就是对M个补丁的描述,共有M行.每行首先是一个整数,表明打该补丁所需要的时间.然后是两个字符串,第 ...

  5. uva 10274 Fans and Gems(隐式图搜索+模拟)

    Fans and Gems Input: Standard Input Output: Standard Output Tomy's fond of a game called 'Fans and G ...

  6. [HNOI2006]最短母串问题 --- AC自动机 + 隐式图搜索

    [HNOI2006]最短母串问题 题目描述: 给定n个字符串(S1,S2.....,Sn),要求找到一个最短的字符串T,使得这n个字符串(S1,S2,......,Sn)都是T的子串. 输入格式: 第 ...

  7. 洛谷 P2622 关灯问题II【状压DP;隐式图搜索】

    题目描述 现有n盏灯,以及m个按钮.每个按钮可以同时控制这n盏灯--按下了第i个按钮,对于所有的灯都有一个效果.按下i按钮对于第j盏灯,是下面3中效果之一:如果a[i][j]为1,那么当这盏灯开了的时 ...

  8. UVA_10603 倒水问题 隐式图搜索

    这道题目是刘汝佳白书上的例题,没有LRJ在白书上提到的划归为搜索问题,还真是一时难以想到好的解法.即三个瓶子,任意的一个状态都是一个节点,最后就划归为一个搜索问题. 由于题目数据量不大,三个杯子容量都 ...

  9. 状态转移的最短路 隐式图搜索 UVA 658

    紫书365 题目大意:给你n个全都是bug的东西,然后每次可以修复,给你修复前后的状态,问最后如果能把bug全都修复,最少需要多少时间. 思路:从最初状态开始,然后枚举bug即可. 表示priorit ...

随机推荐

  1. openwrt 无线中继

    参考: https://wiki.openwrt.org/doc/recipes/relayclient 该方法可以实现中继AP,而不需要AP(WDS)模式.中继后,相当于该路由所有的LAN口以及AP ...

  2. scroll家族属性

    上一篇主要分析了一下offset家族属性,本篇文章则主要是来分析一下scroll家族属性. 首先,scroll家族包括4个属性: 网页正文宽度:document.body.scrollWidth; 网 ...

  3. 运行java飞行记录器JFR(java flight recorder)

    JFR 上面讲到的工具都是作为快速的查看诊断工具的.如果要深入分析问题,可以选择使用内置的Java飞行记录器:Java Mission Control. 转储JFR需要三步: 1. 创建一个包含了你自 ...

  4. Oracle 小技巧

    Oracle小技巧 ###add at 18-10-11 1  ed 在sqlplus当中 如果前一条语句输入有误的话 可以输入ed再回车.在进行编辑 输入ed后有弹窗,可以对之前的输入语句进行编辑 ...

  5. ssh 免密码登录linux

    就两步,take it easy! step1. 在A-PC生成公钥和密钥对 ssh-keygen -t rsa step2. 将A-PC公钥上传至B-PC ssh-copy-id abby@.xxx ...

  6. tesseract-ocr4.0 安装部署及训练验证码识别

    1.  下载最新版本的leptonica,  leptonica-1.74.1.tar.gz   2. 编译安装 tar -zxvf leptonica-.tar.gz cd leptonica- . ...

  7. Jmeter(二)Jmeter目录介绍

    看过许多有关Jmeter的博客,算得上的收获颇丰:不过最牛逼的博客还是“官方文档”,官方文档是ApacheJmeter自己对自己产品的说明,论起对自己产品的理解程度,那肯定是自己嘛...因此推荐大家从 ...

  8. [UE4]先报告后广播模式

    解决客户端射击,在服务器端和其他客户端看不到的问题. 一.把要广播的操作封装成一个事件(函数不支持网络属性),选择“多路传送” 二.创建一个事件,选择“在服务器上运行” 总结:从客户端执行的事件报告到 ...

  9. SCCM2012 R2实战系列之六:安装客户端代理软件

    在安装客户端代理软件之前,请大家确保已经对本系列的第四和第五部分有了基本了解,而且对SCCM环境做了初始化配置和发现方法.我们目前讨论的是加域的计算机,对于工作组的计算机还需要进行额外的配置.在上篇文 ...

  10. 高通平台读写nv总结

    一,引言      1. 什么是NV       高通平台的NV,保存了系统运行过程中各个模块可能用到的一些参数值,它是以单个文件的形式保存在EFS中,但用户是不能随意访问的,只能通过QXDM来进行读 ...