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

唐山外贸网站建设哈尔滨个人建站模板

唐山外贸网站建设,哈尔滨个人建站模板,pc网站建设意见,网络服务电话贪心算法 跳跃游戏跳跃游戏2 跳跃游戏 题目 拿到题目就暴力穷举,我用的是dfs,加上备忘录之后还是超出时间限制。就考虑一下贪心算法。你想 我在[0,n-2]位置遍历求出可以跳跃的最远距离,用farthest更新最大值,如果>终点就返回t…

贪心算法

  • 跳跃游戏
  • 跳跃游戏2

在这里插入图片描述
在这里插入图片描述

跳跃游戏

题目在这里插入图片描述
拿到题目就暴力穷举,我用的是dfs,加上备忘录之后还是超出时间限制。就考虑一下贪心算法。你想 我在[0,n-2]位置遍历求出可以跳跃的最远距离,用farthest更新最大值,如果>=终点就返回true。

DFS递归:时间复杂度最坏是O(N*N)
在这里插入图片描述

class Solution {//dfsint[]memo;public boolean canJump(int[] nums) {memo=new int[nums.length];//memo[i]我在下标i出能不能到达终点 能1 不能0 没有访问-1Arrays.fill(memo,-1);//我站在下标为0的位置 求能不能跳到终点return dfs(nums,0);}//定义:从startIndex为起点,返回能不能到达终点boolean dfs(int[]nums,int startIndex){//到了终点 返回trueif(startIndex==nums.length-1){return true;}//startIndex曾经访问过,不再重复访问if(memo[startIndex]!=-1){return memo[startIndex]==1;}int steps=nums[startIndex];//可以跳跃几步for(int i=1;i<=steps;i++){//跳跃i步 看看我在下标startIndex+i位置可不可以到达终点if(dfs(nums,startIndex+i)==true){memo[startIndex+i]=1;return true;}}return false;}
}

贪心:时间复杂度O(N)

class Solution {public boolean canJump(int[] nums) {int n=nums.length;int farthest=0;for(int i=0;i<n-1;i++){//不断更新最远index 在i位置的最远距离是i+nums[i]farthest=Math.max(farthest,i+nums[i]);if(farthest<=i){return false;}}return farthest>=n-1;}
}

跳跃游戏2

题目在这里插入图片描述

class Solution {//dfs 暴力穷举final int bigVal=100000;int[] memo;public int jump(int[] nums) {int sz=nums.length;memo=new int[sz];//memo[i]:记录在下标为i处到达终点的最小步数Arrays.fill(memo,-1);return dfs(nums,0);}//定义:以startIndex为起点,返回到达终点的最小跳跃次数int dfs(int[]nums,int startIndex){//起点就是终点 跳跃0步if(startIndex==nums.length-1){return 0;}//曾经访问过if(memo[startIndex]!=-1){return memo[startIndex];}//不可跳跃if(nums[startIndex]==0){return bigVal;}int minStep=bigVal;int steps=nums[startIndex];//从startIndex可以跳steps步for(int i=1;i<=steps;i++){//找出最小的跳跃次数if(startIndex+i<nums.length){memo[startIndex+i]=dfs(nums,startIndex+i);minStep=Math.min(minStep,memo[startIndex+i]+1);}}return minStep;}
}

贪心:O(N)

class Solution {//贪心 public int jump(int[] nums) {int farthest=0,end=0,jump=0;int sz=nums.length;for(int i=0;i<sz-1;i++){farthest=Math.max(farthest,nums[i]+i);//可以跳到[i+1,farthest]之间,if(i==end){jump++;end=farthest;}}return jump;}
}
http://www.dtcms.com/wzjs/535876.html

相关文章:

  • 直播网站 咋做我的营业执照网上查询
  • 专门做眼镜的网站东莞网站网络
  • 东莞公司官网建站长泰597人才网最新招聘信息
  • 成都网站建设高端刷单做任务的网站
  • 怎么查工程项目信息seo现在还有前景吗
  • 做网站用c语言可以吗西部数码网站助手
  • 普通网站一年要多少钱网站建设服务器租赁
  • 自己做的视频网站如何赚钱吗小企业网站建设哪些好办
  • 网站服务器搭建及配置的具体步骤成都微信小程序分类信息开发
  • 销售类网站开发架构沈阳创新网站建设报价
  • wordpress 留言板 插件常见的系统优化软件
  • 商务网站开发流程有三个阶段福田建设网站
  • 微网站开发平台广州建立网站的公司
  • 乐思网站建设wordpress 修改页面
  • 合肥做微网站建设网站建设与网页设计从入门到精通 素材下载
  • 全国加盟网站大全媒体发稿公司
  • 如何用visual做网站网站这么绑定到域名
  • 软件下载网站如何履行安全管理义务确保提供的软件wordpress主题 彩票
  • 网站维护英文个人交养老保险价格表
  • 网站建设预算表格个人申请公司流程
  • icp网站授权函手机免费个人网站建站
  • 优秀网站设计 pdf中国建设银行官方网站悦生活
  • php在线购物网站建设个人注册入口官网
  • 用phpmysql做网站wordpress 生成二维码
  • 个人网站建设详细教程无锡市建设银行总行网站
  • 如何做网站的营销西安网站制作开发
  • 建设银行天津分行门户网站时空赣州网
  • 美食网站开发开题报告接工程的app软件
  • 怎么制作外贸网站软件设计师中级
  • 乔托运智能建站百度行发代理商