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

北京通州网站建设潍坊百度快速排名优化

北京通州网站建设,潍坊百度快速排名优化,web开发技术学什么,江安网站建设划分字母区间 题目 我的思路&#xff1a;第一次没有一点思路&#xff0c;第二次看了官网思路后&#xff0c;写的以下答案&#xff0c;没有搞明白循环遍历&#xff0c; //是不对的以下&#xff1a; class Solution {public List<Integer> partitionLabels(String s) {Li…

划分字母区间

题目
我的思路:第一次没有一点思路,第二次看了官网思路后,写的以下答案,没有搞明白循环遍历,
//是不对的以下:

class Solution {public List<Integer> partitionLabels(String s) {List<Integer> list=new ArrayList<>();int[] endPos=new int[26];for(int i=0;i<s.length();i++){endPos[s.charAt(i)-'a']=i;}int end=0,start=0;while(start!=s.length()-1){for(int i=start;i<=end;i++){end=Math.max(end,endPos[i]);//这样结束的不对!,不跳出来怎么能加到list结果里呢}list.add(end-start+1);start=end+1;}return list;}
}

官方答案:

class Solution {public List<Integer> partitionLabels(String s) {int[] last = new int[26];int length = s.length();for (int i = 0; i < length; i++) {last[s.charAt(i) - 'a'] = i;}List<Integer> partition = new ArrayList<Integer>();int start = 0, end = 0;for (int i = 0; i < length; i++) {end = Math.max(end, last[s.charAt(i) - 'a']);if (i == end) {partition.add(end - start + 1);start = end + 1;}}return partition;}
}作者:力扣官方题解
链接:https://leetcode.cn/problems/partition-labels/solutions/455703/hua-fen-zi-mu-qu-jian-by-leetcode-solution/
来源:力扣(LeetCode)
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

55. 跳跃游戏

题目
我的思路:加入从0跳到第i个位置,那么0i之间的所有位置都可以到达,遍历0 i之间的所有位置,看它最远能到哪里,然后看最后能超过n-1,超过了说明能跳到n-1。但是又是很模糊的感觉,不知道具体怎么去“遍历”。
看了答案后写的:
注意思路是维护的是一个变量即最远能到达的位置,不是为每个位置都维护,这与上一题不同,上一题记录的是每个字母最远能到的位置。

class Solution {public boolean canJump(int[] nums) {int far=0;for(int i=0;i<=far;i++)//这里每次结束遍历的都是到最远的位置,官方答案是n,里面加了个if判断{far=Math.max(far,i+nums[i]);if(far>=nums.length-1)return true;}return false;}
}

45. 跳跃游戏II

题目
我的思路: 这道题目说的是跳到最后一个位置最少需要多少步,每个位置都能跳到最后一个位置,所以为了让步数最小,每次应该跳的最远,即i+nums[i]这么长,借鉴上一个的思路,维护的是最小的步数变量,遍历的还是整个数组。后来写出来不对,感觉可以用动态规划来做?
我写的有问题:超出时间限制(待解决)


//错误!!!!!
class Solution {public int jump(int[] nums) {int n=nums.length;int res=Integer.MAX_VALUE;for(int i=0;i<n;i++){int count=0;for(int j=i;j<n;){j=j+nums[j];      count++;         }res=Math.min(res,count+1); //最小是一步?}return res;}
}

官方答案思路:
方法1:倒着往前推。此处贪心的思路是:有多个可以跳到最后一个位置的情况时,也就是对应下标最小的那个。

class Solution {public int jump(int[] nums) {int position=nums.length-1;int step=0;while(position>0) //等于0就没必要跳了{for(int i=0;i<position;i++){if(i+nums[i]>=position){position=i;step++;break;}}}return step;}
}

方法2:正着往前推(待解决)

http://www.dtcms.com/wzjs/21587.html

相关文章:

  • 网站切换中英文北京刚刚传来特大消息
  • 中国互联网网站性能宁波seo教程行业推广
  • 电销系统开发东莞公司seo优化
  • 重庆承越网站建设公司百度热搜榜第一
  • 免费商城网站建设内容营销
  • wordpress网站名称函数网上推广培训
  • 扁平化网站建设公司企业如何进行宣传和推广
  • 做网站接私单网络推广app是违法的吗
  • WordPress中文旅游模板windows优化大师官方网站
  • 做搜狗pc网站优化点抖音搜索引擎优化
  • 有网站模板怎么做网站宁波网站快速优化
  • 网站备案需要的资料所有的竞价托管公司
  • 美食网站设计的代码优秀软文营销案例
  • 合肥网站运营天津搜索引擎优化
  • 即墨建网站价格网页制作模板的网站
  • 网站建设用户需求表自己创建一个网站需要多少钱
  • 电商 网站模板永久域名查询
  • 什么叫网站根目录2023疫情第三波爆发时间
  • 效果图制作网站网络营销外包
  • 网站广告做的好的企业案例分析百度浏览器app
  • 网站更换域名网站seo专员招聘
  • 一个主机可以做几个网站域名百度收录规则2022
  • 解聘 人力资源网站上怎么做推广页面制作
  • 建设银行信用卡管理中心网站首页品牌营销包括哪些内容
  • 国产做爰网站郑州全域静态管理
  • 迪庆公司网站开发方法世界比分榜
  • 车商城网站建设成都门户网站建设
  • 四川省建设厅的注册中心网站seo优化培训课程
  • 查找做像册的网站郑州seo外包公司哪家好
  • html网页设计代码购物网站win7优化设置