ACM集训的Day3 B。。。盲目搜索之DFS。。。
milk
一.题目描述:
gzp有三个容量分别是A,B,C升的桶,A,B,C分别是三个从1到20的整数, 最初,A和B桶都是空的,而C桶是装满牛奶的。有时,农民把牛奶从一个桶倒到 另一个桶中,直到被灌桶装满或原桶空了。当然每一次灌注都是完全的。由于节约, 牛奶不会有丢失
写一个程序去帮助gzp找出当A桶是空的时候,C桶中牛奶所剩量的所有可能性。
二.格式:
INPUT FORMAT:
单独的一行包括三个整数A,B和C。
OUTPUT FORMAT:
只有一行,升序地列出当A桶是空的时候,C桶牛奶所剩量的所有可能性
三.样例:
输入:8 9 10
输出:1 2 8 9 10
输入 2 5 10
输出 5 6 7 8 9 10
时间限制:10000 ms
空间限制:128 M
分析:
用DFS(深度优先搜索)
因为牛奶的总量是不变的,所以可以用a,b中的牛奶量做状态,初始状态是(0,0),每次只能有6种选择,a倒b,a倒c,b倒a,b倒c,c倒a,c倒b。
ps:代码里面有注释。。。我依旧懒懒的 -*>0<* ╮(╯▽╰)╭
&最近睡眠时间严重不足T T
代码:
#include <iostream>
#include<cstring>
using namespace std;
int a,b,c,tf[][];
void dfs(int i, int k) { //dfs深度优先搜索
if (tf[i][k])return; //判重作用
tf[i][k] = ; //标记搜索
dfs(,k); //如果C的剩余容量大于等于A的牛奶量,则把A倒空,A为0,B为k A->C
dfs(i,); //如果C的剩余容量大于等于B的牛奶量,则把B倒空,A为i,B为0 B->C
if (i>=b-k)dfs(i-b+k,b); //A的牛奶量大于等于B的剩余容量,将 B填满,则 A牛奶量为i-(b-k) A->B
else dfs(,i+k); //A的牛奶量小于B剩余容量,把A倒空,则B中有i+k斤牛奶 A->B
if (k>=a-i)dfs(a,k-a+i); //如果B的牛奶量大于等于A的剩余容量,那么把A填满,A中有a斤,B中有k-(a-i) B->A
else dfs(i+k,); //如果B中的牛奶量小于A的剩余容量,把B倒空,A中有i+k斤牛奶 B->A
int j=c-i-k; //令j为C的牛奶量
if (j>=a-i)dfs(a,k); //如果C的牛奶量大于等于A的剩余容量,把A填满,则A中有a斤,C中有j-(a-i),B中有k C->A
else dfs(i+j,k); //如果C的牛奶量小于A的剩余容量,把C倒空,则 A为i+j,C为0,B为k C->A
if (j>=b-k)dfs(i,b); //如果C的牛奶量大于等于B的剩余容量,把B填满,则A为i,B为b,C为j-(b-k) C->B
else dfs(i,k+j); //如果C的牛奶量小于B剩余容量,把C倒空,则A为i,B为k+j,C为0 C->B
}
int main() {
scanf("%d%d%d",&a,&b,&c);
memset(tf,,sizeof(tf)); //初始化tf数组,所有情况为false
dfs(, ); //不向A,B倾倒牛奶的情况
for (int i=b,bol=;i>=;i--) //B的牛奶量上限为b
if (tf[][i]){ //如果这种[0][i]情况可以存在,则tf[0][i]==1(true)
if(bol)cout<<' '; //定义的类似bool值标记作用的bol变量,控制当是第一个数据的时候不输出空格
else bol=; //不是第一个数据的时候会输出空格
cout<<c-i; //输出C的可能的牛奶量。
}
cout << endl;
}
ACM集训的Day3 B。。。盲目搜索之DFS。。。的更多相关文章
- 8.6 正睿暑期集训营 Day3
目录 2018.8.6 正睿暑期集训营 Day3 A 亵渎(DP) B 绕口令(KMP) C 最远点(LCT) 考试代码 A B C 2018.8.6 正睿暑期集训营 Day3 时间:5h(实际) 期 ...
- yzm10的ACM集训小感
7月30号,ACM集训进行了两周,一切都已on the right way.这时的我适时地从题海中探出头,其实除了刷题,也该写点什么来总结下过去.首先,在第一周里,我学习了数据结构,知道了STL这么一 ...
- 【寒假集训系列DAY3】
DAY2的坑之后会补上 DAY3 今天暴力分拿的还是不错的...60+30+25=115,但还是太弱了呀,每题都只会暴力(话说第3题直接输-1给了15分,本以为只会给5分,然后打了半个小时的爆搜... ...
- HDU ACM 1078 FatMouse and Cheese 记忆化+DFS
题意:FatMouse在一个N*N方格上找吃的,每一个点(x,y)有一些吃的,FatMouse从(0,0)的出发去找吃的.每次最多走k步,他走过的位置能够吃掉吃的.保证吃的数量在0-100.规定他仅仅 ...
- [ACM] ZOJ 3816 Generalized Palindromic Number (DFS,暴力枚举)
Generalized Palindromic Number Time Limit: 2 Seconds Memory Limit: 65536 KB A number that will ...
- ACM学习之路___HDU 5723(kruskal + dfs)
Abandoned country Time Limit: / MS (Java/Others) Memory Limit: / K (Java/Others) Total Submission(s) ...
- 牛客国庆集训派对Day3 B Tree
Tree 思路: 树形dp 注意0不存在逆元,任何一个数乘以0就变成0了,就没有价值浪,所以要暴力转移 代码: #pragma GCC optimize(2) #pragma GCC optimize ...
- 牛客网国庆集训派对Day3题目 2018年
链接:https://www.nowcoder.com/acm/contest/203/D来源:牛客网 Shopping 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 524288K ...
- 牛客国庆集训派对Day3 Solution
A Knight 留坑. B Tree 思路:两次树形DP,但是要考虑0没有逆元 可以用前缀后缀做 #include <bits/stdc++.h> using namespa ...
随机推荐
- eclipse 粘贴字符串自动添加转义符
eclipse -> Window -> Preferences -> Java -> Editor -> Typing -> 勾选{Escape text whe ...
- 微信支付Native扫码支付模式二之CodeIgniter集成篇
CI:3.0.5 微信支付API类库来自:https://github.com/zhangv/wechat-pay 请先看一眼官方场景及支付时序图:https://pay.weixin.qq.com/ ...
- Winform实现用多线程、百度地图API解析某公司的物理地址
前言 作为一个很挫的C#新手总喜欢自己写点儿不着边际的东西,本人是个新手加菜鸟,写B/S的,工作中,任务完成了,空闲下来,总想继续学点儿什么,由此触发了本篇文章了.个人一直认为,.NET中,C/S所要 ...
- CozyRSS开发记录1-原型图与Grid
CozyRSS开发记录1-原型图与Grid 1.使用MockPlus画出最简陋的原型图 这个界面参考了目前我最常使用的RSS阅读-傲游浏览器的内置RSS阅读器.主体框架划分为上.左下.右下三块,分别是 ...
- linux yum安装jdk
>>>>>>>>>> 实例: yum安装jdk 1.查看当前的jdk版本,并卸载 (注1:rpm -qa ###解释:查询所有安装的rpm包 ...
- 借鉴dubbo实现自定义缓存
自定义缓存一般基于ConcurrentMap实现,实现缓存需要注意的点是缓存容器对象 本身依赖于 static final去存储对象,样例: ConcurrentMap<String, Gene ...
- PHP 检查并创建多级目录
<?php //检查并创建多级目录 function checkDir($path){ $pathArray = explode('/',$path); $no ...
- Linux学习总结
1.软链接和硬链接 ln 命令可用来创建硬链接或是符号链接.它的使用方式有两种. ln file link 用来创建硬链接 ln -s item link 用来创建符号链接,这里的item可以是文件也 ...
- linux 限制root SSH登陆和限制su
linux 限制root用户SSH登录: 1.修改SSHD服务的配置文件/etc/ssh/sshd_config 将#PermitRootLogin yes 改为PermitRootLogi ...
- NOIp #2009
http://files.cnblogs.com/files/radiumlrb/NOIP2009%E6%8F%90%E9%AB%98%E7%BB%84%E5%A4%8D%E8%B5%9B%E8%AF ...