LeetCode 1130. Minimum Cost Tree From Leaf Values
原题链接在这里:https://leetcode.com/problems/minimum-cost-tree-from-leaf-values/
题目:
Given an array arr of positive integers, consider all binary trees such that:
- Each node has either 0 or 2 children;
- The values of arrcorrespond to the values of each leaf in an in-order traversal of the tree. (Recall that a node is a leaf if and only if it has 0 children.)
- The value of each non-leaf node is equal to the product of the largest leaf value in its left and right subtree respectively.
Among all possible binary trees considered, return the smallest possible sum of the values of each non-leaf node. It is guaranteed this sum fits into a 32-bit integer.
Example 1:
Input: arr = [6,2,4]
Output: 32
Explanation:
There are two possible trees. The first has non-leaf node sum 36, and the second has non-leaf node sum 32. 24 24
/ \ / \
12 4 6 8
/ \ / \
6 2 2 4
Constraints:
- 2 <= arr.length <= 40
- 1 <= arr[i] <= 15
- It is guaranteed that the answer fits into a 32-bit signed integer (ie. it is less than 2^31).
题解:
From the example, see that it is better to remove smaller element first.
Remove small element i and the cost is arr[i] * Math.min(arr[i-1], arr[i+1]). minimum cost happens between smaller values of i-1 and i+1.
Remove until there is only one element and sum of cost is the answer.
Use stack to maintain decreasing order, when there is bigger value num, then pop small value arr[i] and acculate the cost arr[i] * Math.min(num, stk.peek()).
Time Complexity: O(n). n = arr.length.
Space: O(n).
AC Java:
 class Solution {
     public int mctFromLeafValues(int[] arr) {
         if(arr == null || arr.length < 2){
             return 0;
         }
         int res = 0;
         Stack<Integer> stk = new Stack<>();
         stk.push(Integer.MAX_VALUE);
         for(int num : arr){
             while(stk.peek() <= num){
                 int mid = stk.pop();
                 res += mid*Math.min(stk.peek(), num);
             }
             stk.push(num);
         }
         while(stk.size() > 2){
             res += stk.pop()*stk.peek();
         }
         return res;
     }
 }
LeetCode 1130. Minimum Cost Tree From Leaf Values的更多相关文章
- leetcode1130 Minimum Cost Tree From Leaf Values
		思路: 区间dp. 实现: class Solution { public: int mctFromLeafValues(vector<int>& arr) { int n = a ... 
- LeetCode 1000. Minimum Cost to Merge Stones
		原题链接在这里:https://leetcode.com/problems/minimum-cost-to-merge-stones/ 题目: There are N piles of stones ... 
- LeetCode 983. Minimum Cost For Tickets
		原题链接在这里:https://leetcode.com/problems/minimum-cost-for-tickets/ 题目: In a country popular for train t ... 
- [LeetCode] 857. Minimum Cost to Hire K Workers 雇佣K名工人的最低成本
		There are N workers. The i-th worker has a quality[i] and a minimum wage expectation wage[i]. Now w ... 
- [LeetCode] 857. Minimum Cost to Hire K Workers 雇K个工人的最小花费
		There are N workers. The i-th worker has a quality[i] and a minimum wage expectation wage[i]. Now w ... 
- 【LeetCode】Minimum Depth of Binary Tree   二叉树的最小深度 java
		[LeetCode]Minimum Depth of Binary Tree Given a binary tree, find its minimum depth. The minimum dept ... 
- [LeetCode] Minimum Cost to Merge Stones 混合石子的最小花费
		There are N piles of stones arranged in a row. The i-th pile has stones[i] stones. A move consists ... 
- Leetcode之动态规划(DP)专题-详解983. 最低票价(Minimum Cost For Tickets)
		Leetcode之动态规划(DP)专题-983. 最低票价(Minimum Cost For Tickets) 在一个火车旅行很受欢迎的国度,你提前一年计划了一些火车旅行.在接下来的一年里,你要旅行的 ... 
- LeetCode 1135. Connecting Cities With Minimum Cost
		原题链接在这里:https://leetcode.com/problems/connecting-cities-with-minimum-cost/ 题目: There are N cities nu ... 
随机推荐
- Mesh网格简化
			Mesh简化算法: 1. 通过mesh简化,可以将一个多边形的网格A转化成另一个网格B 网格B相比A,有更少的三角形面.边.顶点. 2. 简化的过程是受到一定的约束的.会有一系列自定义的质量标准来控制 ... 
- (五)pdf的构成之文件体(catalog对象)
			引自:https://blog.csdn.net/steve_cui/article/details/82735039 目录(catalog): 文档目录包含对定义文档内容的其他对象的引用.它还包含声 ... 
- 【Oracle】获取SQL执行计划
			一.plsql developer工具F5 在sqldeveloper中选中sql按F5即可查看执行计划 
- POI2015 WYC
			也许更好的阅读体验 \(\mathcal{Description}\) 给定一张n个点m条边的带权有向图,每条边的边权只可能是1,2,3中的一种.将所有可能的路径按路径长度排序,请输出第k小的路径的长 ... 
- nmon2influxdb+grafana:服务监控可视化部署
			在工作中,无论是定位线上问题,还是性能优化,都需要对前端.后台服务进行监控.而及时的获取监控数据,能更好的帮助技术人员排查定位问题. 前面的博客介绍过服务端监控工具:Nmon使用方法及利用easyNm ... 
- 利用windows服务实现整点报时功能
			程序语言:C# 实现目标:程序托管自动运行,每到整点播放语音报时. 准备素材:00——23点的整点报时声音文件. 实现过程: 1.新建windows服务项目 2.添加安装程序 3.设置服务属性 [添加 ... 
- 快数据时代下,Moka携手DataPipeline提升招聘效能
			新时代下,招聘早已不再是过去被动式的流程管控行为,智能化的招聘技术被越来越多地运用到企业招聘中. 为能更好地帮助企业优化招聘渠道,提高招聘效率,提升雇主品牌,Moka从成立之初便秉承“简单”的逻辑,通 ... 
- Resource interpreted as Document but transferred with MIME type application/json
			转自:https://blog.csdn.net/just_lover/article/details/81207472 我在修改并保存后,界面返回提示“undifine”,实际我是看到有返回提示的. ... 
- 知识扩展——(转)一篇文章彻底弄懂Base64编码原理
			在互联网中的每一刻,你可能都在享受着Base64带来的便捷,但对于Base64的基础原理又了解多少?今天这篇博文带领大家了解一下Base64的底层实现. 一.Base64的由来 目前Base64已经成 ... 
- php导出数据到csv
			序言 php导出数据到csv是一种很常见的功能,且csv相比于excel文件有其一定的优势,首先csv对数据的行数没有限制,但是excel对数据的行数有一定的限制,因此,csv文件对于导出大量的数据来 ... 
