zoukankan      html  css  js  c++  java
  • 1167. Minimum Cost to Connect Sticks 一直选取最小值来拼棍子

    You have some number of sticks with positive integer lengths. These lengths are given as an array sticks, where sticks[i] is the length of the ith stick.

    You can connect any two sticks of lengths x and y into one stick by paying a cost of x + y. You must connect all the sticks until there is only one stick remaining.

    Return the minimum cost of connecting all the given sticks into one stick in this way.

     

    Example 1:

    Input: sticks = [2,4,3]
    Output: 14
    Explanation: You start with sticks = [2,4,3].
    1. Combine sticks 2 and 3 for a cost of 2 + 3 = 5. Now you have sticks = [5,4].
    2. Combine sticks 5 and 4 for a cost of 5 + 4 = 9. Now you have sticks = [9].
    There is only one stick left, so you are done. The total cost is 5 + 9 = 14.
    

    Example 2:

    Input: sticks = [1,8,3,5]
    Output: 30
    Explanation: You start with sticks = [1,8,3,5].
    1. Combine sticks 1 and 3 for a cost of 1 + 3 = 4. Now you have sticks = [4,8,5].
    2. Combine sticks 4 and 5 for a cost of 4 + 5 = 9. Now you have sticks = [9,8].
    3. Combine sticks 9 and 8 for a cost of 9 + 8 = 17. Now you have sticks = [17].
    There is only one stick left, so you are done. The total cost is 4 + 9 + 17 = 30.
    

    Example 3:

    Input: sticks = [5]
    Output: 0
    Explanation: There is only one stick, so you don't need to do anything. The total cost is 0.


    就是用q啊

        public int connectSticks(int[] sticks) {
            PriorityQueue<Integer> pq = new PriorityQueue<>();
            for (int s : sticks) {
                pq.offer(s);
            }
            int sum = 0;
            while (pq.size() > 1) {
                int two = pq.poll() + pq.poll();
                sum += two;
                pq.offer(two);
            }
            return sum;
        }
     
  • 相关阅读:
    【林】Ubuntu下安装和设置 OpenSSH Server
    吐吐槽
    【不定时推荐】这些年读过的书第一本--《一个人的朝圣》
    source insight 和keil 编辑对齐
    WeifenLuo DockContent停靠窗口的大小设置
    指针无法保存值
    php 练习基础
    php 写日志
    数据库设计——字段类型设计
    .net用TreeView实现CheckBoxes全选 反选 子节选中 传值
  • 原文地址:https://www.cnblogs.com/immiao0319/p/15201781.html
Copyright © 2011-2022 走看看