求Python的各位帮忙看看,用python语言实现“最小代价生成树”问题的分支限界算法
3条回答 默认 最新
关注 def mctFromLeafValues( arr): res = 0 while len(arr) > 1: min_val = min(arr) idx = arr.index(min_val) if idx > 0 and idx < len(arr) - 1: #有左有右 left_val, right_val = arr[idx - 1], arr[idx + 1] elif idx == len(arr) - 1: #有左没右 left_val, right_val = arr[idx - 1], 16 #为什么是16?因为最大只有15 elif idx == 0: #有右没左 left_val, right_val = 16, arr[idx + 1] res += min(min_val * left_val, min_val * right_val) arr.remove(min_val) #把当前最小值删掉,已经用完了 return res arr = [5,1,4] print(mctFromLeafValues(arr))
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 1无用
悬赏问题
- ¥15 系统 24h2 专业工作站版,浏览文件夹的图库,视频,图片之类的怎样删除?
- ¥15 怎么把512还原为520格式
- ¥15 MATLAB的动态模态分解出现错误,以CFX非定常模拟结果为快照
- ¥15 求高通平台Softsim调试经验
- ¥15 canal如何实现将mysql多张表(月表)采集入库到目标表中(一张表)?
- ¥15 wpf ScrollViewer实现冻结左侧宽度w范围内的视图
- ¥15 栅极驱动低侧烧毁MOSFET
- ¥30 写segy数据时出错3
- ¥100 linux下qt运行QCefView demo报错
- ¥50 F1C100S下的红外解码IR_RX驱动问题