倒水问题 C/C++实现方法

2024-01-16 21:38
文章标签 c++ 实现 问题 方法 倒水

本文主要是介绍倒水问题 C/C++实现方法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、题目

倒水问题:
给定 2 个没有刻度容器,对于任意给定的容积,求出如何只用两个瓶装出 L 升的水,如果可以,输出步骤,如果不可以,请输出 No Solution

二、解题思路

这个题刚开始一点想法都没有,原本把这当成一个数学问题来想(就那种纯数学),后来突然想起来这个是在搜索算法下的一个实验题,于是我开始往这方面靠,搜索算法,我首先想到的就是DFS和BFS,这道题我就是 用BFS来解决的。

我们首先想这个是否真的符合BFS来解决呢,其实分析不难发现,对于两个杯子倒水问题其实也就是8种情况,而且每一步都是这8种情况,那这样其实就有点符合BFS算法来找路径了。

假设有两个杯子为X,Y其实每一步都是固定的在进行操作,一共有八种操作:
(1)把X装满
(2)把Y装满
(3)把X倒空
(4)把Y倒空
(5)X向Y中倒水,X倒完,Y没有被装满
(6)X向Y中倒水,Y被装满
(7)Y向X中倒水,Y倒完,X没有被装满
(7)Y向X中倒水,X被装满。
废话不多说直接上代码

三、代码

int x,y,L;
struct pool{int x,y;string s;
}current;
queue<pool> q;
bool visited[100][100];
string BFS()
{q.push(current);visited[current.x][current.y] = 1;while(!q.empty())//队列中还有元素{current=q.front();q.pop();if(current.x == L || current.y == L)return current.s;if(!visited[x][current.y])//把X装满{current.x = x;current.s += "把x装满\n";visited[current.x][current.y] = 1;q.push(current);}if(!visited[current.x][y])//把Y装满{current.y = y;current.s+="把Y装满\n";visited[current.x][current.y] = 1;q.push(current);}if(!visited[0][current.y])//把X倒空{current.x = 0;current.s+="把x倒空\n";visited[current.x][current.y] = 1;q.push(current);}if(!visited[current.x][0])//把y倒空{current.y = 0;current.s += "把y倒空\n";visited[current.x][current.y] = 1;q.push(current);}if((current.x + current.y <= y) && !visited[0][current.y + current.x])//把x中的水倒入y中,x倒完,y没有被装满{current.y = current.x + current.y;current.x = 0;current.s += "把x中的水倒入y中,x倒完,y没有被装满\n";visited[current.x][current.y] = 1;q.push(current);}if((current.x + current.y > y) && !visited[current.x + current.y - y][y])//把x倒入y中,y被装满{current.x = current.x + current.y - y;current.y = y;current.s+="把x倒入y中,y被装满\n";visited[current.x][current.y] = 1;q.push(current);}if((current.x + current.y <= x) && !visited[current.x + current.y][0])//把y中的水倒入x中,y倒完,x没有被装满{current.x = current.x + current.y;current.y = 0;current.s+= "把y中的水倒入x中,y倒完,x没有被装满\n";visited[current.x][current.y] = 1;q.push(current);} else if((current.x + current.y > x) && !visited[x][current.y + current.x - x])//把y倒入x中,x被倒满{current.y = current.x + current.y - x;current.x = x;current.s+="把y倒入x中,x被倒满\n";visited[current.x][current.y] = 1;q.push(current);}}return "No Solution";
}

运行结果

image.png

这篇关于倒水问题 C/C++实现方法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/613972

相关文章

idea maven编译报错Java heap space的解决方法

《ideamaven编译报错Javaheapspace的解决方法》这篇文章主要为大家详细介绍了ideamaven编译报错Javaheapspace的相关解决方法,文中的示例代码讲解详细,感兴趣的... 目录1.增加 Maven 编译的堆内存2. 增加 IntelliJ IDEA 的堆内存3. 优化 Mave

Java String字符串的常用使用方法

《JavaString字符串的常用使用方法》String是JDK提供的一个类,是引用类型,并不是基本的数据类型,String用于字符串操作,在之前学习c语言的时候,对于一些字符串,会初始化字符数组表... 目录一、什么是String二、如何定义一个String1. 用双引号定义2. 通过构造函数定义三、St

springboot filter实现请求响应全链路拦截

《springbootfilter实现请求响应全链路拦截》这篇文章主要为大家详细介绍了SpringBoot如何结合Filter同时拦截请求和响应,从而实现​​日志采集自动化,感兴趣的小伙伴可以跟随小... 目录一、为什么你需要这个过滤器?​​​二、核心实现:一个Filter搞定双向数据流​​​​三、完整代码

SpringBoot利用@Validated注解优雅实现参数校验

《SpringBoot利用@Validated注解优雅实现参数校验》在开发Web应用时,用户输入的合法性校验是保障系统稳定性的基础,​SpringBoot的@Validated注解提供了一种更优雅的解... 目录​一、为什么需要参数校验二、Validated 的核心用法​1. 基础校验2. php分组校验3

如何解决mmcv无法安装或安装之后报错问题

《如何解决mmcv无法安装或安装之后报错问题》:本文主要介绍如何解决mmcv无法安装或安装之后报错问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录mmcv无法安装或安装之后报错问题1.当我们运行YOwww.chinasem.cnLO时遇到2.找到下图所示这里3.

浅谈配置MMCV环境,解决报错,版本不匹配问题

《浅谈配置MMCV环境,解决报错,版本不匹配问题》:本文主要介绍浅谈配置MMCV环境,解决报错,版本不匹配问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录配置MMCV环境,解决报错,版本不匹配错误示例正确示例总结配置MMCV环境,解决报错,版本不匹配在col

Python实现AVIF图片与其他图片格式间的批量转换

《Python实现AVIF图片与其他图片格式间的批量转换》这篇文章主要为大家详细介绍了如何使用Pillow库实现AVIF与其他格式的相互转换,即将AVIF转换为常见的格式,比如JPG或PNG,需要的小... 目录环境配置1.将单个 AVIF 图片转换为 JPG 和 PNG2.批量转换目录下所有 AVIF 图

Pydantic中model_validator的实现

《Pydantic中model_validator的实现》本文主要介绍了Pydantic中model_validator的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价... 目录引言基础知识创建 Pydantic 模型使用 model_validator 装饰器高级用法mo

Vue3使用router,params传参为空问题

《Vue3使用router,params传参为空问题》:本文主要介绍Vue3使用router,params传参为空问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录vue3使用China编程router,params传参为空1.使用query方式传参2.使用 Histo

AJAX请求上传下载进度监控实现方式

《AJAX请求上传下载进度监控实现方式》在日常Web开发中,AJAX(AsynchronousJavaScriptandXML)被广泛用于异步请求数据,而无需刷新整个页面,:本文主要介绍AJAX请... 目录1. 前言2. 基于XMLHttpRequest的进度监控2.1 基础版文件上传监控2.2 增强版多