用python语言实现“最小代价生成树”问题的分支限界算法
求解答……
1条回答 默认 最新
关注def mctFromLeafValues(self, arr): """ :type arr: List[int] :rtype: int """ 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本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报