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

常用网站开发模式关键字广告

常用网站开发模式,关键字广告,品牌网站建设服务,网络服务工程师安全生产责任制最新版通过万岁!!! 题目:给你一个链表,然后让你从链表中移除一些节点,移除的规则就是我们选择的这个节点在原链表中往右不能有比这个节点大的值。思路:这个题我最开始以为是双指针,然后找…

通过万岁!!!

  • 题目:给你一个链表,然后让你从链表中移除一些节点,移除的规则就是我们选择的这个节点在原链表中往右不能有比这个节点大的值。
  • 思路:这个题我最开始以为是双指针,然后找最大值就好了。其实如果给的是数组的话双指针的方法也应该是可以的。但是他给的是一个链表,我们就不太好通过index处理了。其实问题的关键就是我们找到一个地方以后,如何倒推处理前面的。想到倒退,我们其实可以考虑到栈了。我们将满足的条件的元素进行入栈(也就是说,栈内的元素就是临时想要的链表),但是如果我们当前遍历的节点大于栈顶元素,那么栈顶元素就不是我们要找的元素,这时候就要将栈顶元素出栈,栈顶元素会一直出栈,直到栈顶元素的值大于当前节点或者栈顶元素为空,我们就把当前元素入栈。其实还存在一个问题,就是我们最后如何将栈顶元素构建成一个list。这个问题其实我们只要用ret标记栈底元素,然后每次加入元素的时候,都让栈顶元素指向这个元素就好了。如果栈是空的,则直接让ret指向这个元素就好了。最后返回ret。这样就ok了。但是我不太清楚为啥这个思路的时间复杂度不太好。
  • 技巧:栈
class Solution {public ListNode removeNodes(ListNode head) {if (head == null || head.next == null) {return head;}ListNode ret = head;Stack<ListNode> stack = new Stack<>();while (head != null) {if (stack.isEmpty()) {stack.push(head);ret = head;} else {while (!stack.isEmpty() && stack.peek().val < head.val) {stack.pop();}if (!stack.isEmpty()) {stack.peek().next = head;} else {ret = head;}stack.push(head);}head = head.next;}return ret;}
}
  • 总结:这个题还是比较有意思的,里面的小点也是比较多的。主要是如何考虑到用栈来解决这个问题,这一步感觉还是比较关键的,剩下的地方都是锦上添花了。
http://www.khdw.cn/news/44125.html

相关文章:

  • 重庆响应式网站建设公司天津网站优化软件
  • 一键开启网站网络营销的概念及特点
  • 济南建设网站平台百度云盘
  • 网站友情链接对方网站没有加入本站链接对本站有没有影响?温州seo结算
  • 网站设计怎么做超链接网站排名优化软件
  • 做网站 php java哈尔滨网站优化
  • 做网站入什么会计科目seo专员很难吗
  • 遵义在线武汉seo首页
  • 济宁营销型网站建设网络营销技巧
  • 建筑设计咨询公司要不要资质黑帽seo什么意思
  • 佛山网站建设网站制作公司哪家好外贸营销型网站
  • 济南网站APP合肥网站seo整站优化
  • 什么网站可以接设计方案徐州网站设计
  • 丹东东港seo的形式有哪些
  • 高邮城乡建设网站新网站快速排名软件
  • 做学校网站秦皇岛seo排名
  • 网站设计方案报价营销的目的有哪些
  • 政府与机构类网站网站模板建站公司
  • 巴市建网站北京做的好的seo公司
  • 企业形象设计包括哪些杭州seo关键词优化公司
  • 做网站秒杀软件用什么语言好网站推广100种方法
  • 顺的网站建设要多少钱百度关键词排名神器
  • 欧阳网站建设如何用模板做网站
  • 合肥网站设计制作百度搜索指数查询
  • 邢台做网站费用网络营销策划ppt范例
  • 获取整个网站源码工具网络推广代理
  • 如何用asp编写网站后台怎么推广网站链接
  • 邹城网站制作整合营销是什么
  • 做网站注册页面如何创建个人网站免费
  • 网站建设公司资质找小网站的关键词