热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

java重量组件遮挡_leetcode1046(最后一块石头的重量)Java语言实现

求:每一回合,从中选出两块最重的石头,然后将它们一起粉碎。假设石头的重量分别为x和y,且x

求:

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

如果 x &#61;&#61; y&#xff0c;那么两块石头都会被完全粉碎&#xff1b;

如果 x !&#61; y&#xff0c;那么重量为 x 的石头将会完全粉碎&#xff0c;而重量为 y 的石头新重量为 y-x。

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

示例&#xff1a;

输入&#xff1a;[2,7,4,1,8,1]

输出&#xff1a;1

解释&#xff1a;

先选出 7 和 8&#xff0c;得到 1&#xff0c;所以数组转换为 [2,4,1,1,1]&#xff0c;

再选出 2 和 4&#xff0c;得到 2&#xff0c;所以数组转换为 [2,1,1,1]&#xff0c;

接着是 2 和 1&#xff0c;得到 1&#xff0c;所以数组转换为 [1,1,1]&#xff0c;

最后选出 1 和 1&#xff0c;得到 0&#xff0c;最终数组转换为 [1]&#xff0c;这就是最后剩下那块石头的重量。

提示&#xff1a;

1 <&#61; stones.length <&#61; 30

1 <&#61; stones[i] <&#61; 1000

解&#xff1a;

1、堆排序

构造大顶堆&#xff0c;每次从堆出弹出2个元素&#xff0c;然后放入2者的差值(0也可以放进去&#xff0c;不会影响判断)&#xff0c;当堆中只有1个元素时返回。

时间复杂度&#xff1a;O(NlogN)

空间复杂度&#xff1a;O(N)

public intlastStoneWeight(int[] stones) {

Queue q &#61; newPriorityQueue<>((integer,t1) -> t1 - integer);for(inti &#61; 0;i

q.offer(stones[i]);}

while(q.size() > 1) {

Integer t1 &#61; q.remove();Integer t2 &#61; q.remove();q.offer(Math.abs(t1 - t2));}

returnq.remove();}

2、直接对原始数组排序

每次都在for循环内部&#xff0c;将最大的2个元素放到数组末尾&#xff0c;然后进行运算&#xff0c;差值放数组末尾&#xff0c;数组倒数第二个元素变成0&#xff0c;在下一次的排序过程中&#xff0c;又会选出新一轮的最大和第二大的数放到数组末尾进行比较&#xff0c;整个过程一共需要持续stones.length-1次&#xff0c;最终返回数组最后一位的元素&#xff0c;它就是最大的。

这种方法是一种原地排序的方法&#xff0c;会改变原始数组。

时间复杂度&#xff1a;O(N^2logN)

空间复杂度&#xff1a;O(1)

public intlastStoneWeight(int[] stones) {

intindex &#61; stones.length- 1;for(inti &#61; 0;i

Arrays.sort(stones);stones[index] -&#61; stones[index-1];stones[index-1] &#61; 0;}

returnstones[stones.length-1];}



推荐阅读
  • 题目描述:Balala Power! 时间限制:4000/2000 MS (Java/Other) 内存限制:131072/131072 K (Java/Other)。题目背景及问题描述详见正文。 ... [详细]
  • Java虚拟机及其发展历程
    Java虚拟机(JVM)是每个Java开发者日常工作中不可或缺的一部分,但其背后的运作机制却往往显得神秘莫测。本文将探讨Java及其虚拟机的发展历程,帮助读者深入了解这一关键技术。 ... [详细]
  • 本文详细探讨了在Java中如何将图像对象转换为文件和字节数组(Byte[])的技术。虽然网络上存在大量相关资料,但实际操作时仍需注意细节。本文通过使用JMSL 4.0库中的图表对象作为示例,提供了一种实用的方法。 ... [详细]
  • 字符串中特定模式出现次数的计算方法
    本文详细探讨了如何高效地计算字符串中特定模式(如'pat')的出现次数,通过实例分析与算法解析,帮助读者掌握解决此类问题的方法。 ... [详细]
  • 管理UINavigationController中的手势返回 - Managing Swipe Back Gestures in UINavigationController
    本文介绍了如何在一个简单的闪存卡片应用中实现平滑的手势返回功能,以增强用户体验。 ... [详细]
  • 本文探讨了在UIScrollView上嵌入Webview时遇到的一个常见问题:点击图片放大并返回后,Webview无法立即滑动。我们将分析问题原因,并提供有效的解决方案。 ... [详细]
  • 贡献转移在计算每个元素的作用的时候,我们可以通过反向枚举作用效果,添加到作用元素的身上,这种方法叫做贡献转移。更正式的说, ... [详细]
  • 深入解析 C++ 中的 String 和 Vector
    本文详细介绍了 C++ 编程语言中 String 和 Vector 的使用方法及特性,旨在帮助开发者更好地理解和应用这两个重要的容器。 ... [详细]
  • 使用Matlab创建动态GIF动画
    动态GIF图可以有效增强数据表达的直观性和吸引力。本文将详细介绍如何利用Matlab软件生成动态GIF图,涵盖基本代码实现与高级应用技巧。 ... [详细]
  • 本文详细介绍了在Luat OS中如何实现C与Lua的混合编程,包括在C环境中运行Lua脚本、封装可被Lua调用的C语言库,以及C与Lua之间的数据交互方法。 ... [详细]
  • 想把一组chara[4096]的数组拷贝到shortb[6][256]中,尝试过用循环移位的方式,还用中间变量shortc[2048]的方式。得出的结论:1.移位方式效率最低2. ... [详细]
  • H5技术实现经典游戏《贪吃蛇》
    本文将分享一个使用HTML5技术实现的经典小游戏——《贪吃蛇》。通过H5技术,我们将探讨如何构建这款游戏的两种主要玩法:积分闯关和无尽模式。 ... [详细]
  • 题目编号:2049 [SDOI2008]Cave Exploration。题目描述了一种动态图操作场景,涉及三种基本操作:断开两个节点间的连接(destroy(a,b))、建立两个节点间的连接(connect(a,b))以及查询两节点是否连通(query(a,b))。所有操作均确保图中无环存在。 ... [详细]
  • 题目描述:计算从起点到终点的最小能量消耗。如果下一个单元格的风向与当前单元格相同,则消耗为0,否则为1。共有8个可能的方向。 ... [详细]
  • RTThread线程间通信
    线程中通信在裸机编程中,经常会使用全局变量进行功能间的通信,如某些功能可能由于一些操作而改变全局变量的值,另一个功能对此全局变量进行读取& ... [详细]
author-avatar
手机用户2602921033
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有