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

便宜网站建设价格肇庆seo按天计费

便宜网站建设价格,肇庆seo按天计费,小型手机网站建设企业,颍上县住房和城乡建设局网站给定一个长度为 n 的 0 索引整数数组 nums。初始位置为 nums[0]。 每个元素 nums[i] 表示从索引 i 向前跳转的最大长度。换句话说#xff0c;如果你在 nums[i] 处#xff0c;你可以跳转到任意 nums[i j] 处: 0 j nums[i] i j n 返回到达 nums[n - 1] 的最…给定一个长度为 n 的 0 索引整数数组 nums。初始位置为 nums[0]。 每个元素 nums[i] 表示从索引 i 向前跳转的最大长度。换句话说如果你在 nums[i] 处你可以跳转到任意 nums[i j] 处: 0 j nums[i] i j n 返回到达 nums[n - 1] 的最小跳跃次数。生成的测试用例可以到达 nums[n - 1]。 示例 1: 输入: nums [2,3,1,1,4] 输出: 2 解释: 跳到最后一个位置的最小跳跃数是2。 从下标为 0 跳到下标为 1 的位置跳1步然后跳3步到达数组的最后一个位置。示例 2: 输入: nums [2,3,0,1,4] 输出: 2提示: 1 nums.length 0 nums[i] 1000题目保证可以到达 nums[n-1] 分解题目 目标求解跳到最后一个位置的最小跳跃数依赖于存在一个位置能跳到最后一个位置题目已经保证此项               跳到这个位置的最小跳跃数。如果用 i 来表示最后一次跳跃i - 1表示的倒数第二次跳跃很明显求解 i 的最小跳跃数可以转换为求解 i - 1的最小跳跃数。 至此可以用动态规划进行解决。 定义dp[ i ]表示跳跃到第 i 个位置的最小跳跃数。dp[n - 1]即为所求边界值dp[0] 0。 对于第 i 个位置可能有多个前置的位置可以跳跃到达我们需要找到其中的最小值即 j from 0 to i if(nums[j]ji) dp[i]min(dp[i],dp[j]1); 完整代码 class Solution { public:int jump(vectorint nums) {int n nums.size();vectorint dp(n,n);dp[0] 0;for(int i 1;i n;i){for(int j 0; j i;j){if(nums[j] j i){dp[i] min(dp[i],dp[j] 1);}} }return dp[n-1];} }; 然而这里的动态规划反而引入了更多的重复计算。 如果换成贪心算法 class Solution { public:int jump(vectorint nums) {int jumps 0;int end 0;int farthest 0;for (int i 0; i nums.size() - 1; i) {farthest max(farthest, nums[i] i);if (i end) {jumps;end farthest;if (end nums.size() - 1) {break;}}}return jumps;} }; jumps是跳跃的次数end是当前的终点farthest是当前点跳跃能够到达的最远点。遍历数组除了最后一个元素因为最后一个元素的位置不需要跳跃自己就能到达自己。我们时刻维护从当前点到达的最远距离当我们到达了当前终点就把最远距离设置成终点这里体现贪心的思想。同时当到达了end时也说明需要进行一次跳跃。 即每次在上次能跳到的范围iend内选择一个能跳的最远的位置也就是能跳到farthest位置的点作为下次的起跳点。 对于初学者这看上去非常的反直觉这是不是局部最优为什么是全局最优如果出现当前跳的最远但是下下步跳得近了怎么办 这里需要理解end的作用如果把end抽象成一个分隔符所谓跳跃过程就是在数组内插入分隔符的过程使最终分出的子数组数量最小。 而fareset的作用是保留上一个end到当前end这个区间范围内可以达到的最远值。 注意区间范围这个点。 在贪心算法中每一步的end都是当前范围能到达的最远点也即最大值farest所以最终分出的间隔就会更少。 下面用一个具体图例做进一步解释初始状态进行第一次跳跃 跳跃后在区间内遍历维护最远值farest 这里有人可能会说看起来像恰好1就跳到了较大值10。那如果我们把这里的1换成0会发生什么 可以看到维护的farest才是起到关键作用的值。和nums[end]中的值并无全部关系。 这也是上面提到的保留上一个end到当前end这个区间范围内可以达到的最远值。 图中箭头描述的是end变化的过程真实的跳跃过程和end的变化过程数量相同但是路径不一定相同。每条end箭头仅对应一条跳跃比如这里是从2跳到3跳到10。 继续遍历 只要理解了end表示间隔且和真实跳跃一一对应farest表示一个区间内跳到的最远距离这两个概念这里的贪心算法就很好理解了。
http://www.pierceye.com/news/139433/

相关文章:

  • 简洁大气企业网站模板西安个人做网站
  • 做一个网站需要到哪里做辽宁同鑫建设网站
  • 开发网站监控推荐扬中市建设局网站
  • 手机网站根目录简述一个网站设计的主要步骤
  • 网站改版seo建议网页设计师的能力
  • 网站上线前应该备案吗温州网站建设风格
  • 网站建设书籍免费聊城市东昌府区建设路小学网站
  • 网站标题优化怎么做找人一起做素材网站
  • 如何创建个人网站模板用织梦做模板网站
  • 平台建站建设做网站一定要有营业执照吗
  • 如何把学校网站建设好天猫店铺购买
  • 网站的建设和推广企业网站建设的主要目的是
  • html5 公众号 网站开发工程公司名称
  • 公司做网站那家好网站二维码怎么制作
  • 鼓楼区建设房产和交通局网站网站全屏图片怎么做
  • 外贸订单流失严重番禺网站建设优化推广
  • 做网站送邮箱电商网站建设行情
  • f2c网站建设珠海手机网站建设费用
  • 网站建设的策划书wordpress相册代码
  • 直播网站创做上海网站制作公司哪
  • 如何承接网站建设外包昆明专业网站设计公司
  • 网站做关键词库的作用trellis wordpress
  • 建设一个网站需要哪些硬件设备关键词查询爱站网
  • 17网站一起做网店普宁个人网站备案名称填写的注意事项
  • 好的专业网站建设公司asp300源码
  • 问卷调查网站赚钱一流的盐城网站建设
  • 前端网站推荐常德农科院网站
  • 域名注册网站建设方案网站建设一般多少钱
  • 宁波网站推广找哪家重庆市建设工程信息网官网怎么查看
  • 大创意网站wordpress影视主题