无脑博士的试管们--dfs搜素
无脑博士有三个容量分别是A,B,C升的试管,A,B,C分别是三个从1到20的整数,最初,A和B试管都是空的,而C试管是装满硫酸铜溶液的。有时,无脑博士把硫酸铜溶液从一个试管倒到另一个试管中,直到被灌试管装满或原试管空了。当然每一次灌注都是完全的。由于无脑博士天天这么折腾,早已熟练,溶液在倒的过程中不会有丢失。
写一个程序去帮助无脑博士找出当A是个是空的时候,C试管中硫酸铜溶液所剩量的所有可能性。
输入包括一行,为空格分隔开的三个数,分别为整数A,B和C。
输出包括一行,升序地列出当A试管是空的时候,C试管溶液所剩量的所有可能性。
思路:因为要求A为空的时候C剩余量的可能,仔细想想这咋算,还有B容器呢,无从下手,百度了一下,参考的大神的思路,终于明白了,因为是A为空,因此C中的液体的最后状态只能一部分在C中一部分在B中,因此可将装问题转化成当A为空时B的量,由此可想到,先求出A,B容器在博士每次交换液体时的状态量,最后在这么多状态量中选择A为空的时候的状态量
代码如下(参考大神的)
#include<stdio.h>
#include<string.h>
int a,c,b,A,B,C;//a,b,c代表此时A,B,C容器有多少水
int vis[][];//用VIS数组来表示每次变换时的A,B杯的状态
void dfs(int a,int b,int c){
vis[a][b]=;//状态A杯为a,B杯为b
if(a<A) //当A容器没有装满时的情况
{
if(c>=A-a&&vis[A][b]==)dfs(A,b,c-A+a);//从c倒入a中,C容器里的大于A剩余空间,可装满
if(c<A-a&&vis[a+c][b]==)dfs(a+c,b,); //c倒入a中,C容器里的液体小于A的剩余空间,以下也是
if(b>=A-a&&vis[A][b-A+a]==)dfs(A,b-A+a,c);
if(b<A-a&&vis[a+b][]==)dfs(a+b,,c);
}
if(b<B){
if(c>=B-b&&vis[a][B]==)dfs(a,B,c-B+b);
if(c<B-b&&vis[a][b+c]==)dfs(a,b+c,);//从c倒入b
if(a>=B-b&&vis[a-B+b][B]==)dfs(a-B+b,B,c);//从a倒入b
if(a<B-b&&vis[][a+b]==)dfs(,a+b,c);
}
if(c<C){
if(a>=C-c&&vis[a-C+c][b]==)dfs(a-C+c,b,C);
if(a<C-c&&vis[][b]==)dfs(,b,a+c);;//从a倒入c
if(b>=C-c&&vis[a][b-C+c]==)dfs(a,b-C+c,C);
if(b<C-c&&vis[a][]==)dfs(a,,b+c);//从b倒入c
}
}
int main(){
scanf("%d%d%d",&A,&B,&C);
memset(vis,,sizeof(vis));
dfs(,,C);
int flag=;
for(int i=B;i>=;i--){ //以B的状态来观察A为空的状态
if(vis[][i])
{
if(flag)
flag=;
else printf(" ");
printf("%d",C-i);
}
}
return ;
}
原文链接: http://blog.csdn.net/usher_ou/article/details/59186790
无脑博士的试管们--dfs搜素的更多相关文章
- 计蒜客 无脑博士的试管们 【dfs】
题目链接:https://nanti.jisuanke.com/t/31 题目大意: 无脑博士有三个容量分别是A,B,C 升的试管,A,B,C 分别是三个从 1 到20 的整数,最初,A 和 B 试管 ...
- 计蒜客 无脑博士 bfs
题目链接无脑博士的试管们 思路:直接模拟倒水过程即可,但是需要记忆判断当前的情况是否已经处理过.dfs和bfs都ok AC代码 #include <cstdio> #include < ...
- CodeForces 909E Coprocessor(无脑拓扑排序)
You are given a program you want to execute as a set of tasks organized in a dependency graph. The d ...
- 【原】无脑操作:express + MySQL 实现CRUD
基于node.js的web开发框架express简单方便,很多项目中都在使用.这里结合MySQL数据库,实现最简单的CRUD操作. 开发环境: IDE:WebStorm DB:MySQL ------ ...
- Go语言及Web框架Beego环境无脑搭建
[原]Go语言及Web框架Beego环境无脑搭建 本文涉及软件均以截至到2013年10月12日的最新版本为准 1. 相关软件准备: 1) go1.2rc1.windows-386.msi,对应32位w ...
- 【原】无脑操作:eclipse + maven搭建SSM框架
网上看到一些Spring + Spring MVC + MyBatis框架的搭建教程,不是很详细或是时间久远了,自己动手整一个简单无脑的! 0.系统环境 1)Windows 10 企业版 2)JDK ...
- 【原】无脑操作:ElasticSearch学习笔记(01)
开篇来自于经典的“保安的哲学三问”(你是谁,在哪儿,要干嘛) 问题一.ElasticSearch是什么?有什么用处? 答:截至2018年12月28日,从ElasticSearch官网(https:// ...
- 【原】无脑操作:IDEA + maven + Shiro + SpringBoot + JPA + Thymeleaf实现基础授权权限
上一篇<[原]无脑操作:IDEA + maven + Shiro + SpringBoot + JPA + Thymeleaf实现基础认证权限>介绍了实现Shiro的基础认证.本篇谈谈实现 ...
- 【原】无脑操作:IDEA + maven + Shiro + SpringBoot + JPA + Thymeleaf实现基础认证权限
开发环境搭建参见<[原]无脑操作:IDEA + maven + SpringBoot + JPA + Thymeleaf实现CRUD及分页> 需求: ① 除了登录页面,在地址栏直接访问其他 ...
随机推荐
- [转] react-router4 + webpack Code Splitting
项目升级为react-router4后,就尝试着根据官方文档进行代码分割.https://reacttraining.com/react-router/web/guides/code-splittin ...
- Multi-Fiber Networks for Video Recognition (MFNet)
Motivation:减少时空网络的计算量,保持视频分类精度的基础上,使速度尽可能接近对应网络的2D版本. 为此提出 Multi-Fiber 网络,将复杂网络拆分成轻量网络的集成,利用 fibers ...
- reconnecting-websocket.js
websocket是HTML5下一个不错的网络协议解决方案,有一个场景很多猿猿都会遇到,手机锁屏后大约60秒,IOS会自动断开websocket连接,连接丢失了,那我们的数据也就断了.websocke ...
- alpha冲刺8/10
目录 摘要 团队部分 个人部分 摘要 队名:小白吃 组长博客:hjj 作业博客:冲刺倒计时之8 团队部分 后敬甲(组长) 过去两天完成了哪些任务 首页重新设计 课程时间线确定 答辩准备 接下来的计划 ...
- nginx 301重定向一种实现方法
假设要使用的域名是b.com,以前的老域名是a.com,则以下设置让nginx把a.com的请求访问转发到b.com,并返回301给浏览器. server { listen 80; server_na ...
- H.265:网络视频的高清时代
去年八月,爱立信公司推出了首款H.265编解码器,而在仅仅六个月之后,国际电联(ITU)就正式批准通过了HEVC/H.265标准,标准全称为高效视频编码(High Efficiency Video C ...
- Codeforces 865C Gotta Go Fast 二分 + 期望dp (看题解)
第一次看到这种骚东西, 期望还能二分的啊??? 因为存在重置的操作, 所以我们再dp的过程中有环存在. 为了消除环的影响, 我们二分dp[ 0 ][ 0 ]的值, 与通过dp得出的dp[ 0 ][ 0 ...
- Selenium3详解(基本操作,定位方法)
如果想使用selenium驱动不同的浏览器,必须单独下载并设置不同的浏览器驱动. 基本操作: 刷新:refresh, 获取浏览器窗口大小:get_window_size 设置浏览器窗口大小:set_w ...
- 为表格动态添加一行,miniui组件无效
想要使用miniui实现这样的功能,点击按钮,在一个<td>中动态添加一个miniui输入框和一个按钮,结果miniui的样式无法渲染,请问这种问题可以怎么解决代码如下: <tr&g ...
- Java大数相加-hdu1047
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1047 题目描述: 题意有点绕,但是仔细的读了后就发现是处理大数相加的问题.注意:输入数据有多组,每组输 ...