当前位置: 首页 > news >正文

2024.2.6力扣每日一题——魔塔游戏

2024.2.6

      • 题目来源
      • 我的题解
        • 方法一 贪心+优先队列

题目来源

力扣每日一题;题序:LCP 30

我的题解

方法一 贪心+优先队列

思路:使用贪心的思想,从左到右遍历,若遇到加上当前房间的生命值后小于等于0,由于需要调整的次数最小,则贪心地将当前以及前面房间中生命值最小的移到末尾。直到遍历完所有房间。
具体:在遍历房间的过程中,将为负数的生命值加入到一个小根堆pq中,当计算完每个房间的生命值sum影响后,如果生命值sum小于等于0,则将堆顶元素取出,并使用外的变量other记录从小根堆pq中取出元素的和,这时需要在生命值中补回相应的生命值以及调整次数加1。当遍历完所有房间有,再将other的值重新加入到sum中,若最终的sum小于等于0,则表示无解。

时间复杂度:O(nlogn)。需要遍历一次数组O(n),并且遍历过程中存在优先队列的入队和出队操作O(logn)
空间复杂度:O(n)。最多所有的元素都为负数。

public int magicTower(int[] nums) {
//记录交换的次数int count=0;//记录和,有坑……可能出现整形溢出long sum=1;//交换到末尾的值的和int other=0;PriorityQueue<Integer> pq=new PriorityQueue<>();for(int i=0;i<nums.length;i++){int t=nums[i];//若为负数加入到小根堆if(t<0)pq.offer(t);//更新和sum+=t;//判断更新后的和是否小于等于0if(sum<=0){int temp=pq.poll();//补回生命值sum-=temp;//交换到末尾的和other+=temp;count++;}}//最终加上交换到末尾的负数和sum+=other;return sum>0?count:-1;
}

有任何问题,欢迎评论区交流,欢迎评论区提供其它解题思路(代码),也可以点个赞支持一下作者哈😄~

http://www.lryc.cn/news/329358.html

相关文章:

  • C# OAuth单点登录的实现
  • AtCoder Beginner Contest 347 (ABCDEF题)视频讲解
  • 【vue2+antvx6】报错Cannot read properties of undefined (reading ‘toUpperCase‘)
  • 主流的开发语言、环境及其特点
  • Android知识 - 代码混淆ProGuard规则介绍
  • 【Linux的进程篇章 - 冯诺依曼的体系结构】
  • flask-(数据连接池的使用,定制命令,信号的使用,表关系的建立和查询)
  • 设计模式学习笔记 - 设计模式与范式 -行为型:2.观察者模式(下):实现一个异步非阻塞的EventBus框架
  • 数据挖掘|贝叶斯分类器及其Python实现
  • Linux文件(系统)IO(含动静态库的链接操作)
  • CI/CD实战-jenkins结合ansible 7
  • 内网渗透-(黄金票据和白银票据)详解(一)
  • 学习transformer模型-Dropout的简明介绍
  • 游戏引擎中的大气和云的渲染
  • 华为鲲鹏云认证考试内容有哪些?华为鲲鹏云认证考试报名条件
  • v3-admin-vite 改造自动路由,view页面自解释Meta
  • FIFO存储器选型参数,结构原理,工艺与注意问题总结
  • jvm高级面试题-2024
  • DeepL Pro3.1 下载地址及安装教程
  • 第十一届 “MathorCup“- B题:基于机器学习的团簇能量预测及结构全局寻优方法
  • 云计算探索-如何在服务器上配置RAID(附模拟器)
  • LeetCode226:反转二叉树
  • 特征融合篇 | 利用RT-DETR的AIFI去替换YOLOv8中的SPPF(附2种改进方法)
  • MVCC多版本并发控制
  • 图片转换成base64如何在html文件中使用呢
  • 【MATLAB源码-第24期】基于matlab的水声通信中海洋噪声的建模仿真,对比不同风速的影响。
  • 七、函数的使用方法
  • 数据分析之Tebleau 简介、安装及数据导入
  • 分享一下设计模式的学习
  • 【JavaEE初阶系列】——CAS