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

ssh网站开发的书籍百度seo搜索营销新视角

ssh网站开发的书籍,百度seo搜索营销新视角,宁波seo,网站的总体方案力扣爆刷第108天之CodeTop100五连刷26-30 文章目录 力扣爆刷第108天之CodeTop100五连刷26-30一、15. 字符串相加二、300. 最长递增子序列三、42. 接雨水四、43. 重排链表五、142. 环形链表 II 一、15. 字符串相加 题目链接:https://leetcode.cn/problems/add-strin…

力扣爆刷第108天之CodeTop100五连刷26-30

文章目录

      • 力扣爆刷第108天之CodeTop100五连刷26-30
      • 一、15. 字符串相加
      • 二、300. 最长递增子序列
      • 三、42. 接雨水
      • 四、43. 重排链表
      • 五、142. 环形链表 II

一、15. 字符串相加

题目链接:https://leetcode.cn/problems/add-strings/description/
思路:留一个位置记录余数,每次取一个数下来进行计算,然后反向拼接,然后翻转即可。

class Solution {public String addStrings(String num1, String num2) {StringBuilder res = new StringBuilder();int i = num1.length()-1, j = num2.length()-1, up = 0;while(i >= 0 || j >= 0 || up != 0) {int a = i >= 0 ? num1.charAt(i)-'0' : 0;int b = j >= 0 ? num2.charAt(j)-'0' : 0;int sum = a + b + up;res.append(sum % 10);up = sum / 10;i--;j--;}res.reverse();return res.toString();}
}

二、300. 最长递增子序列

题目链接:https://leetcode.cn/problems/longest-increasing-subsequence/
思路:求最长递增子序列的长度,是非连续的,一层for是解决不了的,定义dp[i]表示区间[0, i]以nums[i]为结尾的最长递增子序列的长度,求dp[i]就要遍历[0,i],每一个位置利用定义进行推导,nums[j]<nums[i],dp[j]是以nums[j]为结尾的区间的最大长度,那么dp[i]=dp[j]+1。

class Solution {public int lengthOfLIS(int[] nums) {int[] dp = new int[nums.length];Arrays.fill(dp, 1);int max = 1;for(int i = 1; i < nums.length; i++) {for(int j = 0; j < i; j++) {if(nums[j] < nums[i]) {dp[i] = Math.max(dp[i], dp[j]+1);}}max = Math.max(dp[i], max);}return max;}
}

三、42. 接雨水

题目链接:https://leetcode.cn/problems/trapping-rain-water/description/
思路:利用单调栈,构造凹槽即可,栈内递减,当前元素大于栈顶,栈顶出栈,出来的这个为凹槽底部,然后利用当前元素为右边界,当前栈顶为左边界,结合出栈的凹槽底部进行雨水容量计算。

class Solution {public int trap(int[] height) {Deque<Integer> stack = new LinkedList<>();int sum = 0;for(int i = 0; i < height.length; i++) {while(!stack.isEmpty() && height[i] > height[stack.peek()]) {int mid = height[stack.pop()];if(!stack.isEmpty()) {int w = i - stack.peek() - 1;int h = Math.min(height[stack.peek()], height[i]) - mid;sum += w*h;}}stack.push(i);}return sum;}
}

四、43. 重排链表

题目链接:https://leetcode.cn/problems/reorder-list/description/
思路:这次写的有点丑陋,下次可以拆分成三个函数来写。具体步骤为三步:
第一步:利用快慢指针寻找链表中点。
第二步:翻转后半部分链表。
第三步:前半部分和后边部分合并即可。


class Solution {public void reorderList(ListNode head) {ListNode slow = head, fast = head;while(fast != null && fast.next != null) {slow = slow.next;fast = fast.next.next;}ListNode p = slow.next, pre = p;slow.next = null;while(p != null) {pre = p.next;p.next = slow.next;slow.next = p;p = pre;}fast = slow.next;slow.next = null;slow = head;while(fast != null) {ListNode spre = slow.next;ListNode fpre = fast.next;slow.next = fast;slow = spre;fast.next = spre;fast = fpre;}}
}

五、142. 环形链表 II

题目链接:https://leetcode.cn/problems/linked-list-cycle-ii/description/
思路:先快慢指针判断是否有环,相遇即有环,然后一个指针从头开始,一个指针从相遇处开始,同步走,相遇便是环的入口。


public class Solution {public ListNode detectCycle(ListNode head) {ListNode slow = head, fast = head;while(fast != null && fast.next != null) {slow = slow.next;fast = fast.next.next;if(slow == fast) {slow = head;while(slow != fast) {slow = slow.next;fast = fast.next;}return slow;}}return null;}
}
http://www.yayakq.cn/news/788122/

相关文章:

  • VIP视频网站有得做吗建筑模板生产厂家
  • 朔州城市建设网站最新国家大事时政新闻
  • 建设电商平台网站wordpress小工具导入
  • 天津网站建设优选企业广州 环保 凡人网站建设
  • 怎么免费做网站不要域名两人合伙做网站但不准备开公司
  • 北京网站建设定制鸿川建设工程有限公司官方网站
  • 域名解析到网站需要怎么做做废旧哪个网站好
  • 泰安网站建设优化关于做网站的策划书
  • 烟台城发建设集团网站wordpress 黑客主题
  • 有口碑的南昌网站设计株洲网站制作公司在哪里
  • 营销网站建设有哪些公司东营市建设管理局
  • 榆林做网站需要注意的几点购物类网站都有哪些模块
  • 杨伟丽 郑州做网站wordpress 去除 栏头
  • 招标网站建设方案济南网站推广效果
  • 成都成华区建设局官方网站h5移动端开发
  • 网站建设首页怎么弄做餐饮培训网站广告
  • 有些网站勤换域名买完域名后怎么做网站
  • 做绿植o2o网站怎么样wordpress 手工升级
  • asp.net 企业网站黄聪开发wordpress主题
  • 长春网站长春网络推广建设网站搜索引擎优化怎么做
  • 欧美网站设计欣赏建设工程网站有哪些
  • python3 网站开发实例网站401错误
  • 电影网站排名怎么做口碑好的广州注册公司
  • 赶集网的二级域名网站怎么做安徽蚌埠网
  • 头像设计制作网站做网站需要哪些人才
  • wordpress做网站过程网站导入
  • 杭州亿向建设有限公司 网站网站后台乱码怎么办
  • php网站开发实例教程书游戏介绍网站模板下载地址
  • 食品建设网站网络电话免费30分钟
  • DW怎么做招聘网站网站网址注册