C语言解决四人/多人过桥问题

article/2025/9/11 21:14:59

参加笔试的时候遇到一道经典的算法题,四人过桥问题。当时没写出来😅。
四人过桥问题:在一个黑夜里,有四个人需要过桥,每次只能通过两人,其中一人必须拿着手电筒;但只有一个手电筒,所以过桥后必须有一个人拿手电筒回来,其他人才能继续过桥。四人过桥的速度分别为:1,2,5,10(分钟);要最慢的那个人过了桥才算真正过桥。求怎样才能最快的全部人都过桥?

#include <stdio.h>
#include <stdbool.h>
int sum = 0;
/*** @description: 过桥-------num,m,sum都是为了打印才设置的参数,可有可无* @param {int} data   存放每个人过桥需要的时间的数组* @param {bool} flat  记录每个人是否过桥的标志,true表示已经过桥,false表示没有过桥* @param {int} num    记录过桥和回来的人的顺序* @param {int} count  总人数* @param {int} n      已经过桥的人数* @param {int} time   记录过桥的总时间* @param {int} m      记录过去或回来的次数* @return {*}*/
void Cross_bridg(int data[],bool flat[],int num[],int count,int n,int time,int m)
{if(n > count)//当过去的人数大于总人数时,退出---不会执行到return;if(n == count)//当过桥的人数等于总人数时,打印信息{printf("%d\n",time);for(int i = 0;i < m;i++){printf("%d",num[i]);if(i%3 == 1)printf("-->\t");else if(i%3 == 2)printf("<--\t");elseprintf(",");}sum++;printf("\n-----------------------------------------sum : %d\n",sum);return;  //递归的回归条件}int k = 0;//这部分默认data数组是已经有序的--从小到大;否则这部分要改一下,重新写获取最小值的代码for(k = 0;k < count;k++)//从已经过桥的人当中选择过桥时间最短的人拿手电筒回来---有点贪心算法感觉,这样可以少运行很多{if(flat[k]){time   += data[k];//回来的人的时间也要算法到过桥的总时间里flat[k] = false;//将回来的人从已经过桥的人当中去除n--;num[m++] = data[k];break;}}int max   = 0;int temp  = 0;int temp1 = 0;for(int i = 0;i < count;i++)//从未过桥的人中选择一个{if(flat[i])//判断这个人是否未过桥continue;flat[i]   = true;for(int j = 0;j < count;j++)//从未过桥的人中选择一个{if(flat[j])//判断这个人是否未过桥continue;max = data[i] > data[j] ? data[i] : data[j];//从这两人中选择过桥时间最大的加入到总时间中if((temp == (data[i] + data[j])) && temp1 == max)//这个判断可以减少一半重复项,例如 1,2 和 2,1continue;flat[j]  = true;//标志为已过桥temp     = data[i] + data[j];temp1    = max;num[m]   = data[i];num[m+1] = data[j];Cross_bridg(data,flat,num,count,n+2,time+max,m+2);//递归//从深一层递归回归后,这里就属于另一种情况的判断,记得将这两人的标志恢复,否则会影响到其它判断flat[j]  = false;}flat[i]   = false;}if(k < count)flat[k] = true;//记得恢复标志return;
}int main()
{int data[] = {1, 2, 5,10};int num[20] = {0};bool flat[4] = {0};Cross_bridg(data,flat,num,4,0,0,0);return 0;
}

在这里插入图片描述
>
C语言实现24点游戏算法
指针、野指针、指针常量、常量指针
C语言实现排序与组合


http://chatgpt.dhexx.cn/article/Y4tfsOGn.shtml

相关文章

小明过桥问题

小明家必须要过一座桥。小明过桥最快要&#xff11;秒&#xff0c;小明的弟弟最快要&#xff13;秒&#xff0c;小明的爸爸最快要&#xff16;秒&#xff0c;小明的妈妈最快要&#xff18;秒&#xff0c;小明的爷爷最快要&#xff11;&#xff12;秒。每次此桥最多可过两人&…

过桥问题

在一个夜黑风高的晚上&#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;最…