小明过桥问题

article/2025/9/11 21:37:15

 

小明家必须要过一座桥。小明过桥最快要1秒,小明的弟弟最快要3秒,小明的爸爸最快要6秒,小明的妈妈最快要8秒,小明的爷爷最快要12秒。每次此桥最多可过两人,而过桥的速度依过桥最慢者而定。过桥时候是黑夜,所以必须有手电筒,小明家只有一个手电筒,而且手电筒的电池只剩30秒就将耗尽。小明一家该如何过桥,请写出详细过程


思路 最快的两个人负责来回传递手电筒,依次最慢的两人过去 右到左

 

function guoQiao(){$arr = quick_sort(func_get_args()); // 排序 从小到大echo '所有过桥人过桥时间,最快两人负责送电筒';dump($arr);$count = count($arr);$path = '';switch ($count) {case 1:echo '一个人过桥<br/>','耗时:',$arr[0];return null;case 2:echo '两个人过桥<br/>','耗时:',$arr[1];return null;}$tip = [$arr[0], $arr[1], 0]; // 0:都在右边 1:慢左快右unset($arr[0]);unset($arr[1]);sort($arr);$time = 0;while ($arr || !$tip[2]) {$time += getTime($tip, $arr, $path);}echo $path,'<br/>','耗时:',$time;
}function getTime(&$tip, &$arr, &$path){$count = count($arr);if ($tip[2] == 0) {$tip[2] = 1;if ($count) {$path .= '小明和弟弟到桥左边'.$tip[1].'<br/>小明送电筒到桥右边'.$tip[0].'<br/>';return $tip[0] + $tip[1];} else {$path .= '小明和弟弟到桥左边'.$tip[1].'<br/>';return  $tip[1];}} else {if ($count > 1) {$tip[2] = 0;$end = array_pop($arr);array_pop($arr);$path .= '桥右边最慢的两人到桥左边'.$end.'<br/>弟弟送电筒到桥右边'.$tip[1].'<br/>';return $end + $tip[1];} else {$end = array_pop($arr);$path .= '小明和最后一人到桥左边'.$end;return $end;}}
}guoQiao(1, 3, 6, 8, 12);


http://chatgpt.dhexx.cn/article/2lRTyYeK.shtml

相关文章

过桥问题

在一个夜黑风高的晚上&#xff0c;有n&#xff08;n < 50&#xff09;个小朋友在桥的这边&#xff0c;现在他们需要过桥&#xff0c;但是由于桥很窄&#xff0c;每次只允许不大于两人通过&#xff0c;他们只有一个手电筒&#xff0c;所以每次过桥的两个人需要把手电筒带回来…

过桥问题的通解

问题一,一个典型过桥问题: 小明一家5口人在夜晚过一座桥,小明过桥要1分钟,小明的弟弟过桥要3分钟,小明的爸爸过桥要6分钟,小明的妈妈过桥要8分钟,小明的爷爷过桥要12分钟;这座桥每次只能过2个人,因是夜晚,过桥时必须提着灯,小明有一只灯,点燃后30分钟会熄灭,问怎…

如何打开tdms文件?

https://www.zhihu.com/question/305029962/answer/1203851780v 下载地址 http://www.ni.com/example/27944/en/ 还有一个综述&#xff0c;写的挺好&#xff01; https://wenku.baidu.com/view/c62700e4aa00b52acec7ca09.html

转载:TDM协议

转自http://www.wangdali.net/i2s/ 1. PCM简介 PCM (Pulse Code Modulation) 是通过等时间隔(即采样率时钟周期)采样将模拟信号数字化的方法。图11为4 bit 采样深度的PCM数据量化示意图。 图11. 4-bit PCM的采样量化 PCM数字音频接口,即说明接口上传输的音频数据通过PCM…

02 - DDMS

目录 一. DDMS 是什么&#xff1f; 二. 工作原理 三. ddmlib 1.ddmlib简介 总结 一. DDMS 是什么&#xff1f; DDMS 的全称是DalvikDebug Monitor Service&#xff0c;是 Android 开发环境中的Dalvik虚拟机调试监控服务。提供测试设备截屏、查看特定进程正在运行的线程以及堆信…

LabVIEW将现有数据文件映射至TDMS数据文件格式

LabVIEW将现有数据文件映射至TDMS数据文件格式 在某些情况下&#xff0c;可能无法使用TDMS文件格式&#xff0c;例如客户或供应商指定必须使用某种格式存储数据。有些传统仪器可能会自动使用某种自定义格式提供数据输出文件。此外&#xff0c;已经用某种方式收集的传统测量数据…

Matlab打开LabVIEW的tdm/tdms文件

1. 下去NI官网下载 MATLAB TDM Example文件 。 网址&#xff1a;Reading TDM/TDMS Files with The MathWorks, Inc. MATLAB Software - NI Community 这里我两个文件都下载了&#xff0c;但是只打开了2020那个&#xff0c;能用我就没看sp2010那个是干嘛的。 2. 使用Matlab打…

Labview-关于TDMS文件逻辑的学习-从今天开始学习Labview

1. TDMS文件的逻辑格式 TDMS文件的逻辑格式遵循TDM三层结构&#xff0c;仍然是文件、通道组、通道三层。用户在使用时只需要关心这三层就行了。2. TDMS文件API TDMS文件格式基本上可以称为NI用在测试测量领域的通用数据文件格式&#xff0c;LabVIEW, CVI/LabWindows, Signal Ex…

[Matlab科学计算] Matlab打开Labview保存的TDMS文件

1. TDMS文件简单介绍 TDMS文件格式由三个层次结构级别组成&#xff1a;文件、组、通道。文件级别可包含任意数量的组&#xff0c;而每个组又可包含任意数量的通道。通过通道分组&#xff0c;用户可以选择如何组织数据以使其更易于理解。每​个​TDMS​文件​都​包含​两​种​…

JAVA解析TDMS文件

2023年更新&#xff1a; 没想到还有人关注&#xff0c;上传了最新代码 https://github.com/yc97/TDMSDecoder 该代码经过测试&#xff0c;基本没什么bug了 reference: http://www.eefocus.com/Junking/blog/12-07/281264_7bf69.html http://www.ni.com/white-paper/14252/zh…

LabVIEW写入可快速加载的TDMS文件

LabVIEW写入可快速加载的TDMS文件 TDMS文件格式的设计目的是在尽可能快地读写数据的同时仍保持足够的灵活性来适应采集过程中通道数量和采样率的变化。 但是数据读写速度快的文件未必可快速加载。 TDMS文件是一个完全的二进制文件&#xff0c;由多个部分数据段组成&#xff0c;…

LabVIEW TDMS连续写入内存增长

LabVIEW TDMS连续写入内存增长 每次执行TDMS写入VI时&#xff0c;内存&#xff08;RAM&#xff09;使用量都会略有增加。这是内存泄漏吗&#xff0c;如何防止内存使用量增加&#xff1f; 解答 此问题有几种可能的解决方案&#xff1a; TDMS文件的引用可能没有适当地关闭。对…

Matlab查看tdms文件

由于最近项目需要使用Labview开发解调设备&#xff0c;对于高速采集卡就需要使用tdms存储数据&#xff08;存储的数据量较大&#xff09;&#xff0c;而用matlab无法对tdms格式文件进行直接读取&#xff0c;所以查找一些相关博客&#xff0c;解决了读取的问题。&#xff08;以下…

Labview数据存储与读取——TDMS文件的创建与写入

Labview数据存储与读取——TDMS文件的创建与写入 你好&#xff0c;这是我在自学Labview编写软件过程中使用的一些功能。我在存储采集卡数据时&#xff0c;通过阅读大量他人的程序&#xff0c;发现TDM及TDMS文件十分适合波形数据的记录&#xff0c;TDMS文件比TDM文件在存储动态…

TDMS转EXCEL

NI官方有推出TDMS转EXCEL插件&#xff0c;安装后可直接用excel打开tdms文件。 下载链接&#xff1a;https://download.csdn.net/download/Kleds_Love/81168914 下载为iSO文件&#xff0c;右键→装载→管理员身份安装即可 安装完成后&#xff0c;直接双击tdms文件&#xff0c;…

计算TDMS文件的THD

1.用采集卡采集一路正弦信号&#xff0c;存为.tdms文件 2.将.tdms文件转成.csv文件或.txt文件或.xlsx文件&#xff0c;使MATLAB可以将数据导入工作空间 法1&#xff1a;将.tdms文件转成.csv文件&#xff08;依靠LabVIEW程序&#xff09; 法2&#xff1a;将.tdms文件转成.txt文件…

如何打开tdms文件

1、下载一个插件 地址&#xff1a;https://www.ni.com/example/27944/en/ 2、下载后按照导向安装即可 3、安装后如果不能打开文件&#xff0c;试试重启电脑&#xff0c;或者你电脑上没有execl软件

用Matlab处理TDMS数据(降噪+频谱分析)

目录 TDMS文件从导入到最终处理的整个过程第一&#xff1a;把TDMS文件导入到matlab用MATLAB TDMS函数使用ConventTDMS函数 第二&#xff1a;把Matlab的数据画出来附录&#xff1a;1-照着步骤依然显示不了图的解决办法附录&#xff1a;2-使用Matlab批量转换".TDMS"文件…

labview的TDMS文件读写

文章目录 一概念介绍1.相关概念2.tdms文件介绍 二.VI介绍1.TDMS打开VI2.TDMS写入3.TDMS读取4.TDMS设置属性5.TDMS获取属性6.TDMS关闭 三.范例分析——TDMS文件 并行读写的操作 写在最前面&#xff1a;本文先介绍TDMS概念和文件结构&#xff0c;然后介绍VI如何使用&#xff0c;最…

插件框架篇一之scrollbars

问题&#xff1a;部分手机&#xff08;如三星&#xff09;ListView或GridView设置scrollbars显示时会报错奔溃。 问题分析&#xff1a; ScrollView继承于View&#xff0c;在View的构造器中初始化scrollbars。 根据initializeScrollbars判断是否需要进行scrollbars初始…