当前位置: 首页 > news >正文

数学建模小练习

题目B

电影《虎胆龙威 3》中,塞谬尔和布鲁斯扮演的主角要拆除西蒙所放的炸弹。西蒙喷泉上面有两个壶,容量分别是5加仑和3加仑,向其中一个壶中加入刚好 4 加仑的水,计时器会停止,否则5分钟后会爆炸。 问题:能够安全拆弹吗?要怎么做?

解:每个状态可以表示为一个元组 (x, y),其中 x 是 5 加仑壶中的水量,y 是 3 加仑壶中的水量。初始状态为 (0, 0),即两个壶都是空的。目标状态是 x = 4,即 5 加仑壶中有 4 加仑水。

可以执行以下几种操作:

填满5加仑壶(x, y) -> (5, y)

填满 3 加仑壶(x, y) -> (x, 3)

倒空 5 加仑壶(x, y) -> (0, y)

倒空 3 加仑壶(x, y) -> (x, 0)

从 5 加仑壶倒水到 3 加仑壶:倒水,直到一个壶空或者另一个壶满。

从 3 加仑壶倒水到 5 加仑壶:同样的,直到一个壶空或者另一个壶满。

BFS搜索方案

from collections import deque
​
# 定义 BFS 函数,返回完整的操作过程
def water_jug_bfs():# 初始状态,两个壶都是空的 (0, 0)initial_state = (0, 0)# 队列用于 BFS,每个元素不仅记录状态,还记录从初始状态到达该状态的路径queue = deque([(initial_state, [])])  # 队列中存放 (状态, 操作路径)# 用于记录已经访问过的状态,防止重复搜索visited = set([initial_state])# 定义壶的容量jug1_capacity = 5jug2_capacity = 3goal = 4  # 我们的目标是 5 加仑壶中正好有 4 加仑水# BFS 搜索过程while queue:current_state, path = queue.popleft()x, y = current_state# 如果达到了目标状态 (5加仑壶中有4加仑水),则返回成功和完整的操作路径if x == goal:return True, path + [(current_state, "最终状态")]# 产生所有可能的下一步状态,并附加上相应的操作说明next_states = [((jug1_capacity, y), "填满 5 加仑壶"),  # 填满5加仑壶((x, jug2_capacity), "填满 3 加仑壶"),  # 填满3加仑壶((0, y), "倒空 5 加仑壶"),              # 倒空5加仑壶((x, 0), "倒空 3 加仑壶"),              # 倒空3加仑壶# 从 5 加仑壶倒水到 3 加仑壶,倒的水量是 min(x, jug2_capacity - y)((x - min(x, jug2_capacity - y), y + min(x, jug2_capacity - y)), f"从 5 加仑壶倒 {min(x, jug2_capacity - y)} 加仑水到 3 加仑壶"),  # 从 3 加仑壶倒水到 5 加仑壶,倒的水量是 min(y, jug1_capacity - x)((x + min(y, jug1_capacity - x), y - min(y, jug1_capacity - x)), f"从 3 加仑壶倒 {min(y, jug1_capacity - x)} 加仑水到 5 加仑壶")]# 对每个可能的下一状态进行处理for next_state, action in next_states:if next_state not in visited:  # 如果没有访问过这个状态visited.add(next_state)    # 标记为访问queue.append((next_state, path + [(current_state, action)]))  # 加入到搜索队列中,并记录路径return False, []  # 如果找不到解,则返回 False 和空路径
​
# 运行 BFS
result, path = water_jug_bfs()
if result:print("可以安全拆除炸弹。操作步骤如下:")for i in range(len(path) - 1):state, action = path[i]print(f"当前状态 (5加仑壶: {state[0]} 加仑, 3加仑壶: {state[1]} 加仑) -> {action}")
else:print("无法安全拆除炸弹")
结果:
可以安全拆除炸弹。操作步骤如下:
当前状态 (5加仑壶: 0 加仑, 3加仑壶: 0 加仑) -> 填满 5 加仑壶
当前状态 (5加仑壶: 5 加仑, 3加仑壶: 0 加仑) -> 从 5 加仑壶倒 3 加仑水到 3 加仑壶
当前状态 (5加仑壶: 2 加仑, 3加仑壶: 3 加仑) -> 倒空 3 加仑壶
当前状态 (5加仑壶: 2 加仑, 3加仑壶: 0 加仑) -> 从 5 加仑壶倒 2 加仑水到 3 加仑壶
当前状态 (5加仑壶: 0 加仑, 3加仑壶: 2 加仑) -> 填满 5 加仑壶
当前状态 (5加仑壶: 5 加仑, 3加仑壶: 2 加仑) -> 从 5 加仑壶倒 1 加仑水到 3 加仑壶

故可以安全拆除炸弹,首先填满5加仑壶,然后将其中的3加仑倒入3加仑壶。接着倒空3加仑壶,并将5加仑壶剩下的2加仑倒入3加仑壶。随后再次填满5加仑壶,并将其中的1加仑倒入3加仑壶。这时,5加仑壶中剩下的正好是4加仑水,从而成功拆除炸弹。

相关文章:

数学建模小练习

题目B 电影《虎胆龙威 3》中,塞谬尔和布鲁斯扮演的主角要拆除西蒙所放的炸弹。西蒙喷泉上面有两个壶,容量分别是5加仑和3加仑,向其中一个壶中加入刚好 4 加仑的水,计时器会停止,否则5分钟后会爆炸。 问题:能够安全拆弹…...

Java爬虫:获取SKU详细信息的艺术

在电子商务的世界里,SKU(Stock Keeping Unit,库存单位)是每个商品的唯一标识符,它包含了商品的详细信息,如尺寸、颜色、价格等。对于商家和开发者来说,获取商品的SKU详细信息对于库存管理、订单…...

心理咨询展示网站建设渠道拓展

心理问题长期以来都受到关注,每个城市里也都有相关服务商家,除了进店外,线上也可以开展咨询服务,对需求者来说需要找到靠谱的品牌,而商家也需要触达到更多客户获取转化。 网站是品牌线上工具,利于商家通过…...

naocs注册中心,配置管理,openfeign在idea中实现模块间的调用,getway的使用

一 naocs注册中心步骤 1 nacos下载安装 解压安装包,直接运行bin目录下的startup.cmd 这里双击运行出现问题的情况下 (版本低的naocs) 在bin目录下 打开cmd 运行以下命令 startup.cmd -m standalone 访问地址: http://localh…...

先进封装技术 Part02---TSV科普

一、引言 随着电子设备向更小型化、更高性能的方向发展,传统的芯片互连技术已经无法满足日益增长的需求。在这样的背景下,TSV(Through-Silicon Via,硅通孔)技术应运而生,成为先进封装技术中的核心之一。 如果我们看大多数主板,可以看到两件事:第一,芯片之间的大多数连…...

【数据挖掘】2023年 Quiz 1-3 整理 带答案

目录 Quiz 1Quiz 2Quiz 3Quiz 1 Problem 1(30%). Consider the training data shown below. Here, A , B A, B A,B, and...

老古董Lisp实用主义入门教程(12):白日梦先生的白日梦

白日梦先生的白日梦 白日梦先生已经跟着大家一起学Lisp长达两个月零五天! 001 粗鲁先生Lisp再出发002 懒惰先生的Lisp开发流程003 颠倒先生的数学表达式004 完美先生的完美Lisp005 好奇先生用Lisp来探索Lisp006 好奇先生在Lisp的花园里挖呀挖呀挖007 挑剔先生给出…...

UE5 Windows热更新解决方案思路(HotPatcher+Tomcat+RuntimeFilesDownloader)

以下个人学习笔记。其中必会存在一些问题,仅作参考。本人版本5.1。 参考视频: UE4热更新:HotPatcher插件使用教程_哔哩哔哩_bilibili 3.检查需要下载的版本_哔哩哔哩_bilibili 参考文章: UE 热更新:Questions &…...

进程管理工具:非daemon进程管理工具supervisor

一、非daemon进程管理工具:supervisor Windows安装supervisor https://pypi.org/project/supervisor-win/4.5.0/#files 一)进程管理supervisor简介 supervisor是一个 Client/Server模式的系统,允许用户在类unix操作系统上监视和控制多个进程&…...

c++模拟真人鼠标轨迹算法

一.鼠标轨迹算法简介 鼠标轨迹底层实现采用 C / C语言,利用其高性能和系统级访问能力,开发出高效的鼠标轨迹模拟算法。通过将算法封装为 DLL(动态链接库),可以方便地在不同的编程环境中调用,实现跨语言的兼…...

android12/13/14版本wms最新面试题:dumpsys window和sf一定会一致么?

背景: 近期学员们学习了马哥wms课程后,去参加相关的大厂的framework面试,有一个学员朋友带回来了一个wms相关的面试题,具体面试题描述如下: 问题1 请问wms的window和SurfaceFlinger的Layer有什么关系? 回…...

Python脚本示例,你可以使用这个脚本来自动化登录网站、选择页面元素和提交表单

devtools 元素页面可以选择元素,copy xpath用于查找 python编程:1、浏览器登录https://58.xxx/ 账号:xxx 密码:FN123456 2、选择“技能训练” 3、选择“云网智能运维员培训相关资料” 4、选择“L1-Linux操作系统与运维题库” 5、依次选择1-50题目&#x…...

安卓13设置动态修改设置显示版本号 版本号增加信息显示 android13增加序列号

总纲 android13 rom 开发总纲说明 文章目录 1.前言2.问题分析3.代码分析4.代码修改5.编译6.彩蛋1.前言 设置 =》关于平板电脑 =》版本号 在这里显示了系统的一些信息,但是这里面的信息并不包含序列号之类的信息,我们修改下系统设置,在这里增加上相关的序列号。 2.问题分析…...

从 Oracle 集群到单节点环境(详细记录一次数据迁移过程)之三:在目标服务器上恢复数据

从 Oracle 集群到单节点环境(详细记录一次数据迁移过程)之三:在目标服务器上恢复数据 目录 从 Oracle 集群到单节点环境(详细记录一次数据迁移过程)之三:在目标服务器上恢复数据一、修改参数文件的内容二、…...

相互作用感知的 3D 分子生成 VAE 模型 - DeepICL 评测

DeepICL 是一个基于相互作用感知的 3D 分子生成模型,能够在目标结合口袋内进行相互作用引导的小分子设计。DeepICL 通过利用蛋白质-配体相互作用的普遍模式作为先验知识,在有限的实验数据下也能实现高度的泛化能力。 一、背景介绍 DeepICL 来源于韩国科学…...

Java实现随机抽奖的方法有哪些

在Java中实现随机抽奖的方法,通常我们会使用java.util.Random类来生成随机数,然后基于这些随机数来选择中奖者。以下将给出几种常见的随机抽奖实现方式,包括从数组中抽取、从列表中抽取以及基于权重的抽奖方式。 1. 从数组中抽取 import ja…...

grafana加载缓慢解决方案

背景 目前随着数据和图表的逐渐增多,Grafana 页面加载速度明显变慢,严重影响了用户体验,几次都有骂娘的冲动.,因此我们需要对 Grafana 进行优化,以提升加载性能。 对于速度优化,我们可以从以下方面进行入…...

【湖南步联科技身份证】 身份证读取与酒店收银系统源码整合———未来之窗行业应用跨平台架构

一、html5 <!DOCTYPE html> <html><head><meta http-equiv"Content-Type" content"text/html; charsetutf-8" /><script type"text/javascript" src"http://51.onelink.ynwlzc.net/o2o/tpl/Merchant/static/js…...

多路复用和事件轮询机制

多路复用&#xff1a;Nio 服务端只有一个线程处理多个连接 事件轮询机制&#xff1a;select 底层用了 epoll。 select open 调用了 epoll 通过3个方法来实现事件轮询 1.epoll.create 创建epoll 多个集合 2.epoll.ctl 如果有事件会把事件挪到就绪事件列表。 3.epoll.wait 会监听…...

Android常用C++特性之std::abs

声明&#xff1a;本文内容生成自ChatGPT&#xff0c;目的是为方便大家了解学习作为引用到作者的其他文章中。 std::abs 是 C 标准库中的一个函数&#xff0c;用于计算整数、浮点数或其他数值类型的绝对值。它返回一个值&#xff0c;该值是参数的非负数形式&#xff0c;即去掉负…...

Windows下OpenClaw全流程指南:ollama GLM-4-7-Flash接入与技能扩展

Windows下OpenClaw全流程指南&#xff1a;ollama GLM-4-7-Flash接入与技能扩展 1. 为什么选择OpenClawGLM-4-7-Flash组合 去年我在处理日常办公自动化时&#xff0c;发现很多重复性工作既耗时又容易出错。尝试过各种RPA工具后&#xff0c;最终被OpenClaw的"AI智能体本地…...

轻量级涨点神器:Ghost卷积模块在YOLOv8中的实战应用与性能优化

1. Ghost卷积模块&#xff1a;轻量化的秘密武器 第一次听说Ghost卷积时&#xff0c;我正为一个嵌入式设备上的目标检测项目发愁。当时需要在树莓派上部署YOLOv3&#xff0c;但模型跑起来像老牛拉车&#xff0c;帧率直接掉到个位数。直到试用了Ghost模块&#xff0c;推理速度直接…...

突破Android固件提取瓶颈:从格式迷宫到一站式解决方案

突破Android固件提取瓶颈&#xff1a;从格式迷宫到一站式解决方案 【免费下载链接】Firmware_extractor 项目地址: https://gitcode.com/gh_mirrors/fi/Firmware_extractor 【痛点场景&#xff1a;固件提取的"格式迷宫"困境】 深夜的开发者工作室里&#xf…...

使用MobaXterm远程开发Retinaface+CurricularFace项目

使用MobaXterm远程开发RetinafaceCurricularFace项目 1. 项目概述与准备工作 RetinafaceCurricularFace是当前人脸识别领域的热门组合方案&#xff0c;Retinaface负责精准的人脸检测和对齐&#xff0c;CurricularFace则提供高质量的人脸特征提取和识别能力。在实际开发中&…...

抖音批量下载工具:高效自动化内容采集解决方案

抖音批量下载工具&#xff1a;高效自动化内容采集解决方案 【免费下载链接】douyin-downloader 项目地址: https://gitcode.com/GitHub_Trending/do/douyin-downloader 在内容创作与数据分析领域&#xff0c;高效获取抖音视频资源是许多从业者面临的共同挑战。传统手动…...

旧设备焕新:OpenCore跨版本升级破局指南

旧设备焕新&#xff1a;OpenCore跨版本升级破局指南 【免费下载链接】OpenCore-Legacy-Patcher 体验与之前一样的macOS 项目地址: https://gitcode.com/GitHub_Trending/op/OpenCore-Legacy-Patcher 痛点诊断&#xff1a;旧Mac的升级困境 每一台Mac都有其生命周期&…...

RuoYi项目部署避坑大全:从宝塔面板配置到前端OpenSSL报错,一次讲清所有常见问题

RuoYi项目部署避坑指南&#xff1a;从错误现象到根治方案 1. 部署前的环境准备与常见陷阱 部署RuoYi这类前后端分离项目时&#xff0c;环境配置往往是第一个拦路虎。不少开发者习惯直接跳到代码部署环节&#xff0c;却忽略了基础环境的兼容性问题。我们先来看看那些容易被忽视的…...

跨平台游戏画质增强工具:OptiScaler打破显卡壁垒的全方位解决方案

跨平台游戏画质增强工具&#xff1a;OptiScaler打破显卡壁垒的全方位解决方案 【免费下载链接】OptiScaler DLSS replacement for AMD/Intel/Nvidia cards with multiple upscalers (XeSS/FSR2/DLSS) 项目地址: https://gitcode.com/GitHub_Trending/op/OptiScaler 在PC…...

基于STM32的NTC热敏电阻温度采集系统设计与实现

1. NTC热敏电阻温度采集系统概述 在工业控制、智能家居和医疗设备等领域&#xff0c;温度监测都是基础且关键的功能。NTC热敏电阻因其成本低、响应快、精度适中的特点&#xff0c;成为温度传感的常见选择。STM32系列微控制器内置高精度ADC模块&#xff0c;与NTC配合能快速搭建经…...

终极GitHub加速解决方案:让你的代码下载速度提升100倍

终极GitHub加速解决方案&#xff1a;让你的代码下载速度提升100倍 【免费下载链接】Fast-GitHub 国内Github下载很慢&#xff0c;用上了这个插件后&#xff0c;下载速度嗖嗖嗖的~&#xff01; 项目地址: https://gitcode.com/gh_mirrors/fa/Fast-GitHub 你是否曾经因为G…...