zoukankan      html  css  js  c++  java
  • 每日算法-15(最后一块石头的重量)

    有一堆石头,每块石头的重量都是正整数。

    每一回合,从中选出两块 最重的 石头,然后将它们一起粉碎。假设石头的重量分别为 x 和 y,且 x <= y。那么粉碎的可能结果如下:

    如果 x == y,那么两块石头都会被完全粉碎;
    如果 x != y,那么重量为 x 的石头将会完全粉碎,而重量为 y 的石头新重量为 y-x。
    

    最后,最多只会剩下一块石头。返回此石头的重量。如果没有石头剩下,就返回 0。

    示例:

    输入:[2,7,4,1,8,1]
    输出:1
    解释:
    先选出 7 和 8,得到 1,所以数组转换为 [2,4,1,1,1],
    再选出 2 和 4,得到 2,所以数组转换为 [2,1,1,1],
    接着是 2 和 1,得到 1,所以数组转换为 [1,1,1],
    最后选出 1 和 1,得到 0,最终数组转换为 [1],这就是最后剩下那块石头的重量。

    来源:力扣(LeetCode)
    链接:https://leetcode-cn.com/problems/last-stone-weight

    class Solution {
        public int lastStoneWeight(int[] stones) {
            if(stones.length == 1)
                return stones[0];
    
            int index = stones.length - 1; 
            Arrays.sort(stones);
            while(stones[index-1] != 0){    
                int x = stones[index-1];
                int y = stones[index];
                if(x == y){
                    stones[index] = stones[index-1] = 0;
                }else{
                    stones[index-1] = 0;
                    stones[index] = y - x;
                }
                Arrays.sort(stones);
            }
            return stones[stones.length-1];
        }
    }
    

    作者:Better又
    出处:https://www.cnblogs.com/lwyy1223-/
    本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。

  • 相关阅读:
    网络流 学习笔记
    回文自动机PAM 学习笔记
    后缀自动机SAM 学习笔记
    题解 CF1207G Indie Album
    题解 CF163E e-Government
    AC自动机 学习笔记
    CCF冬令营Day1上午
    不编译AC记录
    生成函数 抄写笔记
    FFT NTT 学习笔记
  • 原文地址:https://www.cnblogs.com/lwyy1223-/p/12832660.html
Copyright © 2011-2022 走看看