UVA 10603 Fill(正确代码尽管非常搓,网上很多代码都不能AC)
题目链接: option=com_onlinejudge&Itemid=8&page=show_problem&problem=1544">click here~
此题我预计是加强过数据,在我纠结了非常久的时候我交了好几份网上的代码不是WA就是TLE。在我非常迷茫的时候我又交了一份,AC了(尽管我用随机数据找到了他代码一个不能过的数据)。
给了我信心。然后我拿他的代码用随机数跟我的代码进行測试。再用FC找不同。。发现了一个致命的错误。一般来说,BFS或者DFS都是须要有一个vis数组或者哈希来判重,可是此题判重是有非常大问题的,相同对于3个水杯的状态,在3步下或许流量是50,然后这个状态被标记,5步的时候又出现了这个状态(能够理解为还有一个分支),可是流量却是35,假设用个二维数组判重(没有必要用三维的,由于和是一样的,二维就能够了),那么这个状态的流量就不会更新。题目的意思却是说要用最小的流量去到达这个状态,无论是得到终于的目标还是比目标小近期目标的状态。
所以我感觉这题的标准解法应该不是 bfs,由于能够说是算暴力了。每一次的状态(假设流量比上一个到这个状态的流量少)都须要更新,不断更新直到最后。
在uva toolkit上此题的思路是dp或dijkstra。这2样还没怎么搞不太会。建图也想不到想法。感觉就算建了还是搜索的东西啊
尽管A了,可是感觉不爽啊。另外我找的那个A了的代码没过的数据是:33 12 113 6
他的结论是 174 6,我的结论是171 6,在uva toolkit上也是我的答案。可是我认为他的思路应该是正确的,没细看。。实在是太长了。
假设有想法的欢迎留言。
代码供參考:
#include<cstdio>
#include<ctype.h>
#include<algorithm>
#include<iostream>
#include<cstring>
#include<vector>
#include<stack>
#include<cmath>
#include<queue>
#include<set>
using namespace std;
#define ll long long
#define NMAX 20000
typedef int state[3];
state st[NMAX],a;
int pour[NMAX];
int record[205];
int target;
int vis[205][205],vispour[205][205];
int try_to_insert(int x,int tpour)
{
state &k = st[x];
if(vis[k[0]][k[1]] != 1 || vispour[k[0]][k[1]] > tpour)
{
vis[k[0]][k[1]] = 1;
vispour[k[0]][k[1]] = tpour;
return 1;
}
return 0;
}
int main()
{
// freopen("input.txt","r",stdin);
// freopen("o.txt","w",stdout);
int i,j,t,ans;
scanf("%d",&t);
while(t--)
{
memset(record,0,sizeof(record));
memset(vis,0,sizeof(vis));
memset(vispour,0,sizeof(vis));
scanf("%d%d%d%d",&a[0],&a[1],&a[2],&target);
st[1][0] = st[1][1] = 0;
st[1][2] = a[2];
memset(pour,0,sizeof(pour));
record[a[2]] = 1;
int front = 1,rear = 2;
vis[0][0] = 1;
bool flag = false;
while(front < rear)
{
for(i = 0; i < 3; i++)
if(record[st[front][i]] == 0 || pour[record[st[front][i]]] > pour[front])
record[st[front][i]] = front;
for(i = 0; i < 3; i++)
if(st[front][i] == target)
{
if(flag)
ans = pour[ans] > pour[front]?front:ans;
else
ans = front;
flag = true;
break;
}
for(i = 0; i < 3; i++)
{
state &w = st[front];
if(w[i] != 0)
{
for(j = 0; j < 3; j++)
{
if(i == j || (i != j && w[j] == a[j])) continue;
state &temp = st[rear];
memcpy(temp,w,sizeof(w));
int pp;
if(w[i] + w[j] > a[j])
{
pp = a[j] - w[j];
temp[i] = w[i] - pp;
temp[j] = a[j];
}
else
{
pp = w[i];
temp[i] = 0;
temp[j] = w[j] + pp;
}
int tpour;
tpour = pour[front] + pp;
if(try_to_insert(rear,tpour))
{
pour[rear] = tpour;
rear++;
}
}
}
}
front++;
}
if(record[target] == 0)
{
for(i = target; record[i] == 0; i--);
printf("%d %d\n",pour[record[i]],i);
}
else printf("%d %d\n",pour[ans],target);
}
return 0;
}
UVA 10603 Fill(正确代码尽管非常搓,网上很多代码都不能AC)的更多相关文章
- UVa 10603 Fill [暴力枚举、路径搜索]
10603 Fill There are three jugs with a volume of a, b and c liters. (a, b, and c are positive intege ...
- 【路径寻找问题】UVa 10603 - Fill
如家大神书上的例题.第一次接触也是按代码敲得.敲的过程感觉很直观.但自己写估计会写的乱七八糟.以后不能砍得难就不愿意做这种题.否则只能做一些水题了.(PS:48) 紫书 #include<ios ...
- UVA 10603 Fill
题意: 题目的意思是倒水,给出的四个数据是第一个水杯,第二个水杯,第三个水杯,和目标水量.一开始只有第三个水杯是满的,剩下的水杯是空的.倒水的时候只能把倒水出来的这个杯子倒空,或是倒水进去的杯子倒满. ...
- UVa 10603 Fill (暴力BFS+优先队列)
题意:给定4个数,a,b,c,d,分别代表空杯子容积为a,b,一个盛满水的杯子容积为c,让你不断倒水,找一个dd,是不是存在某个时刻, 某个杯子里的水dd,和d相同,或者无限接近.让求最少的倒水量和d ...
- UVA - 10603 Fill(隐式图搜索)
题目大意:经典的倒水问题. 给你三个瓶子,体积为a,b,c. 刚開始a.b是空的,c是满的,如今要求你到出体积为d的水.倒水的规则为,要么倒水方为空,要么接水方满 问倒到容量为d时,倒水的最小体积是多 ...
- UVA - 10603 Fill(BFS求最小值问题)
题目: 给出三个杯子(没有刻度线)的容量,起初之后第三个杯子是满的,其他的两个杯子是空的,容量分别是a.b.c.问最少需要倒多少升水才能让某一个杯子中的水有d升?如果不能恰好做到d升,就让某一个杯子里 ...
- UVA 10603 - Fill BFS~
http://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem&c ...
- UVa 10603 Fill (BFS && 经典模拟倒水 && 隐式图)
题意 : 有装满水的6升的杯子.空的3升杯子和1升杯子,3个杯子中都没有刻度.不使用道具情况下,是否可量出4升水呢? 你的任务是解决一般性的问题:设3个杯子的容量分别为a, b, c,最初只有第3个杯 ...
- 如何正确的加载和执行 JavaScript 代码
无论当前 JavaScript 代码是内嵌还是在外链文件中,页面的下载和渲染都必须停下来等待脚本执行完成.JavaScript 执行过程耗时越久,浏览器等待响应用户输入的时间就越长.浏览器在下载和执行 ...
随机推荐
- Android---intent传递putStringArrayListExtra
Intent是Activity与Activity之间,Activity与Service之间传递参数的介质,使用Intent和Bundle在组件之间传递数据,而这两种通常实现的是Java基本对象类型和S ...
- Elasticsearch 单模式下API的增删改查操作
<pre name="code" class="html">Elasticsearch 单模式下API的增删改查操作 http://192.168. ...
- SqlServer2012导入Oracle详细案例
第一次使用SqlServer2012,界面和VS2012风格一致了,Great! 进入正题,这篇博文主要写一下自己亲测的一个案例,使用SqlServer2012的“导入和导出数据”功能向Oracle1 ...
- hdoj 1233 还是畅通工程(最小生成树)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1233 思路分析:该问题为最小生成树问题,使用kruskal算法或者prim算法即可解决: 代码如下: ...
- HDU 2087 剪花布条 KMP入门
Problem Description 一块花布条,里面有些图案,另有一块直接可用的小饰条,里面也有一些图案.对于给定的花布条和小饰条.计算一下能从花布条中尽可能剪出几块小饰条来呢? Input ...
- 用Aspose.Cells控件读取Excel
Aspose是一个很强大的控件,可以用来操作word,excel,ppt等文件,用这个控件来导入.导出数据非常方便.其中Aspose.Cells就是用来操作Excel的,功能有很多.我所用的是最基本的 ...
- 【前端】一句命令快速合并压缩 JS、CSS
引用自:一句命令快速合并 JS.CSS 在项目开发环境下,我们会把 JS 代码尽可能模块化,方便管理和修改,这就避免不了会出现一个项目自身 JS 文件数量达到10个或者更多. 而项目上线后,会要求将所 ...
- Javabean的理解
1.Javabean是指满足指定规则的Java类.满足的规则由Sun公司提出,如x,setX,getX等规范,public无参构造函数等 2.Javabean其实也是一种规范.
- vim 多文件编辑【超实用】
vim 多文件编辑(偶的linux笔记) http://blog.csdn.net/lcj_cjfykx/article/details/18805721 通过vim打开的每个文件都对应着一个buff ...
- Binary Tree Preorder Traversal and Binary Tree Postorder Traversal
Binary Tree Preorder Traversal Given a binary tree, return the preorder traversal of its nodes' valu ...