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

代码随想录35期Day32-Java

Day32题目

LeetCode122.买股票的最佳时机

核心思想:很简单,只要第二天比第一天贵,就第一天买入,第二天卖出

class Solution {public int maxProfit(int[] prices) {// 只要后一天比这一天价钱高就买,然后第二天卖出int res = 0;for(int i = 1 ; i < prices.length ; i ++ ){if(prices[i] > prices[i-1]){res += prices[i]-prices[i-1];}}return res;}
}

LeetCode55.跳跃游戏

核心思想:只要看最远的跳远距离能到最后一位就可以了

class Solution {public boolean canJump(int[] nums) {// 看跳的最远能覆盖最后一位就行// count是目前能跳的最远距离int count = 0 ;if(nums.length == 1) return true;for(int i = 0 ; i <= count;  i ++){// 更新count为最远跳远距离count = Math.max(count,nums[i]+i);if(count >= nums.length-1) return true;}return false;}
}

LeetCode45跳远游戏Ⅱ:需要计算跳远的最小次数

核心思想:我使用了从后向前的遍历,比较好想但是遍历次数多些。也可以维护一个当前最大距离和最大距离,计算几步最大距离能覆盖到最后一个元素

class Solution {public int jump(int[] nums) {if (nums.length == 1)return 0;int maxCover = 0;int curCover = 0;int count = 0;for (int i = 0; i <= maxCover; i++) {// 更新最大覆盖距离maxCover = Math.max(maxCover, i + nums[i]);// 符合要求的结果if (maxCover >= nums.length - 1) {count++;return count;}// curCover是当时 第一个元素能到达的最远距离// 如果到达了第一个元素能到达的最远距离,那么就该走下一步了if (i == curCover) {count++;// 更新第二步能到达的最大距离 为 第一步覆盖到的元素中最远的一个。curCover = maxCover;}}return count;}
}
// 这是我从后向前遍历的代码
class Solution {public int jump(int[] nums) {if(nums.length == 1) return 0;// 从后向前找最大能到这里的位置// target 记录接下来一步要到达什么地方int target = nums.length- 1;int count = 0 ;while(target !=0 ){int temp = target;for(int i = temp ; i >= 0 ; i --){// 从后向前遍历保证得到的下一步是离得最远的那个。if(nums[i] + i >= temp){if(target> i){target = i;}}}count++;}return count;}
}
http://www.lryc.cn/news/347797.html

相关文章:

  • ROS 2边学边练(45)-- 构建一个能动的机器人模型
  • 【第66例】IPD体系进阶:华为IPD发展历程
  • websevere服务器从零搭建到上线(四)|muduo网络库的基本原理和使用
  • C语言笔记10
  • BMS-HiL主要功能
  • idea无法识别加载pom.xml文件
  • C语言笔记12
  • 说一下 hibernate 的缓存机制?
  • Mac安装jadx
  • 风扇开启执行逻辑
  • 调用函数实现数组的输入排序插入与输出
  • 代码随想录算法训练营Day 41| 动态规划part03 | 343. 整数拆分、96.不同的二叉搜索树
  • 多模态产品在智能文档处理应用的展望------以TextIn模型为例
  • 上海市计算机学会竞赛平台2024年3月月赛丙组最近的数字
  • RFID在汽车制造中的应用如何改变行业
  • sCrypt受邀在中国人民大学举办《区块链与数字经济》课程讲座
  • pc端的鼠标箭头变换
  • ICode国际青少年编程竞赛- Python-2级训练场-for循环练习2
  • RiPro主题美化【支付弹窗底部提示语根据入口不同有不同的提示】ritheme主题美化RiProV2 增加支付提示语,按支付类型不同,入口不同提示语不同的设置
  • MSMQ消息队列
  • 树莓派nmap扫描
  • 【必看】Spring系列面试题
  • wordpress增加谷歌分析
  • linux的信号量的使用
  • C--贪吃蛇
  • element ui的确认提示框按钮样式修改
  • 【vue】keep-alive:true缓存导致页面数据不刷新
  • Golang — map的使用心得和底层原理
  • Oracle如何收缩减小表空间大小
  • 【爬虫】爬取股票历史K线数据写入数据库(三)