UVa10603 Fill
解题思路:这是神奇的一题,一定要好好体会。见代码:
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<queue>
using namespace std;
const int maxn = ;
int vis[maxn][maxn], ans[maxn], cap[]; struct node{
int v[], cnt;
friend bool operator <(node A, node B){
return A.cnt > B.cnt; //cnt更小的优先级更高
}
}; priority_queue<node> q; //优先队列 void Change(node u)
{
for(int i = ; i < ; i++)
{
int d = u.v[i];
//ans[d] < 0表示该点目前没有访问过
//找出走到容量为d的点时所倒水的最小总量
if(ans[d] < || u.cnt < ans[d]) ans[d] = u.cnt;
}
return ;
} void solve(int a, int b, int c, int d)
{
cap[] = a, cap[] = b, cap[] = c; //初始化三个杯子的容量
node s, s1;
//每个杯子中初始状态所含有的水
s.v[] = , s.v[] = , s.v[] = c, s.cnt = ;
vis[][] = ; //标记第一个和第二个杯子中水的状态已经出现过
while(!q.empty()) q.pop();
q.push(s); while(!q.empty())
{
s = q.top();
q.pop(); Change(s); //好好体会
if(ans[d] >= ) break; //表示已经符合题意,可以跳出 //从杯子i中把水倒到杯子j中
for(int i = ; i < ; i++) for(int j = ; j < ; j++)
{
if(i == j) continue; //不可能倒水到自身
if(s.v[i] == || s.v[j] == cap[j]) continue;//i为空或j已经满
int tmp = min(s.v[i], cap[j] - s.v[j]); //到底倒完i还是将j倒满
s1 = s; //s的状态要保存下来,还要进行下一次循环。
//杯子i中的水增加,j中的水减少,总转移两增加
s1.v[i] = s.v[i] - tmp, s1.v[j] = s.v[j] + tmp, s1.cnt = s.cnt + tmp;
if(!vis[s1.v[]][s1.v[]]) //如果这种状态之前没出现过
{
vis[s1.v[]][s1.v[]] = ;
q.push(s1); //入队列
}
} }
while(d >= )
{
if(ans[d] >= ) //符合条件,刚好为题目所说的d,或与它接近
//的最小符合条件的数
{
printf("%d %d\n", ans[d], d);
return ; //直接返回
}
d --;
}
return ;
} int main()
{
int t, a, b, c, d;
scanf("%d", &t);
while(t --)
{
scanf("%d %d %d %d", &a, &b, &c, &d); memset(vis, , sizeof(vis));//一定要初始化
memset(ans, -, sizeof(ans)); solve(a, b, c, d);
}
return ;
}
UVa10603 Fill的更多相关文章
- UVA-10603 Fill (BFS)
题目大意:有三个已知体积但不知刻度的杯子,前两个杯子中初始时没有水,第三个装满水,问是否可以倒出d升水,如果倒不出,则倒出一个最大的d’,使得d’<=d,并且在这个过程中要求总倒水量最少. 题目 ...
- 1.1.1最短路(Floyd、Dijstra、BellmanFord)
转载自hr_whisper大佬的博客 [ 一.Dijkstra 比较详细的迪杰斯特拉算法讲解传送门 Dijkstra单源最短路算法,即计算从起点出发到每个点的最短路.所以Dijkstra常常作为其他算 ...
- 最短路算法详解(Dijkstra/SPFA/Floyd)
新的整理版本版的地址见我新博客 http://www.hrwhisper.me/?p=1952 一.Dijkstra Dijkstra单源最短路算法,即计算从起点出发到每个点的最短路.所以Dijkst ...
- 【UVA10603】Fill (构图+最短路)
题目: Sample Input22 3 4 296 97 199 62Sample Output2 29859 62 题意: 有三个杯子它们的容量分别是a,b,c, 并且初始状态下第一个和第二个是空 ...
- UVA10603 倒水问题 Fill
伫倚危楼风细细,望极春愁,黯黯生天际.草色烟光残照里,无言谁会凭阑意. 拟把疏狂图一醉,对酒当歌,强乐还无味.衣带渐宽终不悔,为伊消得人憔悴.--柳永 题目:倒水问题 网址:https://onlin ...
- iOS 2D绘图 (Quartz2D)之路径(stroke,fill,clip,subpath,blend)
像往常一样 这个系列的博客是跟着大神的脚步来的.按照往例 在此贴出原博客的出处: http://blog.csdn.net/hello_hwc?viewmode=list我对大神的崇拜之情 如滔滔江水 ...
- dev_set_draw的fill和margin模式
注意:分别观察两张填充模式,一种是内部填充,一种是边缘填充.还有一种缺省的填充. Name dev_set_draw — Define the region fill mode. Signature ...
- scala 学习之: list.fill 用法
题目描述: Decode a run-length encoded list. Given a run-length code list generated as specified in probl ...
- 急!JDBC问题,发生通信错误。错误位置:Reply.fill()。消息:数据不足。 ERRORCODE=-4499, SQLSTATE=08001
代码如下:Class.forName("com.ibm.db2.jcc.DB2Driver");Connection conn = DriverManager.getConnect ...
随机推荐
- 十大技巧优化Android App性能
无论锤子还是茄子手机的不断冒出,Android系统的手机市场占有率目前来说还是最大的,因此基于Android开发的App数量也是很庞大的. 那么,如何能开发出更高性能的Android App?相信是软 ...
- Office 2013 note
1.每次打开重新配置: 问题表现:启动后发现每次打开都会出现“正在配置”的进度 执行:reg add HKCU\Software\Microsoft\Office\15.0\Word\Options ...
- 深入浅出ES6(十二):代理 Proxies
作者 Jason Orendorff github主页 https://github.com/jorendorff 请看这样一段代码: var obj = new Proxy({}, { get: ...
- HDU5568/BestCoder Round #63 (div.2) B.sequence2 dp+高精度
sequence2 Problem Description Given an integer array bi with a length of n, please tell me how many ...
- Codeforces Round #335 (Div. 2) D. Lazy Student 贪心
D. Lazy Student Student Vladislav came to his programming exam completely unprepared as usual. He ...
- Spring笔记——Spring框架简介和初次框架配置
Spring简介 Spring是一个开源框架,Spring是于2003 年兴起的一个轻量级的Java 开发框架,由Rod Johnson 在其著作Expert One-On-One J2EE Deve ...
- [转]应聘Java,jsp,j2ee软件工程师笔试中可能出现的问题
相信大家应聘的时候第一关就是笔试,即使是一位很有经验的工程师也不一定能够顺利通过,笔试不好,可能就无法进行面试,即使能够进行面试,考官对你的印象也不会很好,问的问题也会很多,估计很难吃的消,当然如果你 ...
- mongo中查询Array类型的字段中元素个数
I have a MongoDB collection with documents in the following format: { "_id" : ObjectId(&qu ...
- android程序获取WIFI的IP地址和MAC地址
转自:http://my.oschina.net/chenj/blog/68680 近日在鼓捣这玩意,拿出来大家分享一下,代码比较简单,如果有不懂的再问 <Button android:id=& ...
- C# 获取所有打印机
List<string> print = Cprinter.GetLocalPrinter(); /// <summary> /// 获取所有打印机 /// </summ ...