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

如何在腾讯云做网站小型企业管理培训课程

如何在腾讯云做网站,小型企业管理培训课程,企业家居网站建设,衡水移动网站建设价格导语 leetcode刷题笔记记录#xff0c;本篇博客记录数组基础1部分的题目#xff0c;主要题目包括#xff1a; 977.有序数组的平方 #xff0c;209.长度最小的子数组 #xff0c;59.螺旋矩阵II 知识点 滑动窗口 所谓滑动窗口#xff0c;就是不断的调节子序列的起始位…导语 leetcode刷题笔记记录本篇博客记录数组基础1部分的题目主要题目包括 977.有序数组的平方 209.长度最小的子数组 59.螺旋矩阵II 知识点 滑动窗口 所谓滑动窗口就是不断的调节子序列的起始位置和终止位置从而得出我们要想的结果。一般需要用到双指针来进行求解。 模拟 模拟并不涉及到什么算法就是模拟过程但却十分考察对代码的掌控能力。 需要对边界值和循环过程进行仔细的考虑。 Leetcode 977 有序数组的平方 题目描述 给你一个按 非递减顺序 排序的整数数组 nums返回 每个数字的平方 组成的新数组要求也按 非递减顺序 排序。 示例 1 输入 nums [-4,-1,0,3,10] 输出 [0,1,9,16,100] 解释 平方后数组变为 [16,1,0,9,100] 排序后数组变为 [0,1,9,16,100]示例 2 输入 nums [-7,-3,2,3,11] 输出 [4,9,9,49,121]提示 1 nums.length 104-104 nums[i] 104nums 已按 非递减顺序 排序 进阶 请你设计时间复杂度为 O(n) 的算法解决本问题 解法 可以使用双指针从两边往中间走这样会得到一个从大到小排列的数组返回结果时只需要倒置一下就可以了。 class Solution(object):def sortedSquares(self, nums)::type nums: List[int]:rtype: List[int]left, right 0, len(nums) - 1ans_l []while left right:if abs(nums[left]) abs(nums[right]):ans_l.append(nums[left] ** 2)left 1else:ans_l.append(nums[right] ** 2)right - 1return ans_l[::-1]同时也可以令双指针从中间开始即从正负数分界处开始为此需要先找到正负数的分界线代码如下 class Solution(object):def sortedSquares(self, nums)::type nums: List[int]:rtype: List[int]# 寻找分割点cut -1for num in nums:if num 0:cut 1else:break# 这样cut右边都是非负数左边都是负数left, right cut, cut 1ans_l []while left 0 or right len(nums)-1:if left 0:ans_l.append(nums[right] ** 2)right 1elif right len(nums) - 1:ans_l.append(nums[left] ** 2)left - 1elif -nums[left] nums[right]:ans_l.append(nums[left] ** 2)left - 1else:ans_l.append(nums[right] ** 2)right 1return ans_lLeetcode 209 长度最小的子数组 题目描述 给定一个含有 n 个正整数的数组和一个正整数 target 。 找出该数组中满足其和 ****≥ target ****的长度最小的 连续子数组 [numsl, numsl1, ..., numsr-1, numsr] 并返回其长度 。 如果不存在符合条件的子数组返回 0 。 示例 1 输入 target 7, nums [2,3,1,2,4,3] 输出 2 解释 子数组 [4,3] 是该条件下的长度最小的子数组。示例 2 输入 target 4, nums [1,4,4] 输出 1示例 3 输入 target 11, nums [1,1,1,1,1,1,1,1] 输出 0提示 1 target 1091 nums.length 1051 nums[i] 105 解法 最简单的解法为暴力解法但Leetcode上已经提示Python的暴力解法一定会超时所以这里使用滑动窗口来解决这个问题。 暴力解法中一个for循环滑动窗口的起始位置一个for循环为滑动窗口的终止位置那么滑动窗口如何用一个for循环来完成这个操作呢。 一个最关键的问题在于如果用一个for循环那么应该表示滑动窗口的起始位置还是终止位置如果只用一个for循环来表示滑动窗口的起始位置那么如何遍历剩下的终止位置此时难免再次陷入暴力解法的怪圈。所以 只用一个for循环那么这个循环的索引一定是表示 滑动窗口的终止位置。 滑动窗口解法 class Solution(object):def minSubArrayLen(self, target, nums)::type target: int:type nums: List[int]:rtype: intstart, ans 0, 0min_length len(nums) 1for end in range(len(nums)):ans nums[end]while ans target:min_length min(end-start1, min_length)ans - nums[start]start 1return min_length if min_length len(nums) else 0Leetcode 59 螺旋矩阵II 题目描述 给你一个正整数 n 生成一个包含 1 到 n2 所有元素且元素按顺时针顺序螺旋排列的 n x n 正方形矩阵 matrix 。 示例 1 输入 n 3 输出 [[1,2,3],[8,9,4],[7,6,5]]示例 2 输入 n 1 输出 [[1]]提示 1 n 20 解法 这个题目的过程就是模拟需要考虑好边界值条件一个解题的关键是处理好区间选取为了代码统一和边界值统一考虑应选取左开右闭的区间即每一行列都只考虑起始位置点而不考虑终止位置点。 代码如下 class Solution(object):def generateMatrix(self, n)::type n: int:rtype: List[List[int]]matrix [[0] * n for j in range(n)]cnt 1offset 1start_x, start_y 0, 0loop n // 2while loop:for j in range( start_y, n - offset ):matrix[start_x][j] cntcnt 1for i in range( start_x, n - offset ):matrix[i][n-offset] cntcnt 1for j in range( n - offset, start_y, -1):matrix[n-offset][j] cntcnt 1for i in range( n - offset, start_x, -1):matrix[i][start_y] cntcnt 1start_x 1start_y 1offset 1loop - 1if n%2 1:matrix[n//2][n//2] n * n return matrix 参考 代码随想录题解
http://www.hkea.cn/news/14256409/

相关文章:

  • 建站软件可以不通过网络建设吗创作图片的软件
  • dw建设网站的代码模板做网站全屏图片拉长代码
  • 建站交流百度指数怎么用
  • 企业号官网入口江门关键词优化效果
  • ps课堂网站wordpress游戏支付宝
  • 做快三网站网站首页搜索功能的id怎做
  • 私有云网站建设c2c平台名称
  • 便宜网站建设 优帮云wordpress 钉钉
  • 帮人做淘宝网站骗钱画册设计内容
  • 相机拍照的图片怎么做网站呀珠海快速网站建设
  • 怎么搜 织梦的网站家装设计效果图网站
  • 网站建设英文术语电商网站建设在哪里找设计师
  • 四川做网站的公司有哪些音乐分享网站源码
  • 5网站建站环境建设公司属于什么企业
  • 专业网站建设流程专业团队的句子
  • 工作作风建设网站营销手段有哪些方式
  • 建设网站英语南京网站建设包括哪些
  • 企业建站 炫酷模板深圳网站设计公司哪家工艺好
  • 做网站销售怎么样wordpress+移动端m
  • 网站代码优化本地安装网站无法连接数据库
  • 两个男性做网站哪个公司建网站
  • 重庆vr制作广州网站优化排名系统
  • 弹窗广告最多的网站有网站源码如何搭建自己的网站
  • 怎么做赌钱网站网站排名监控工具
  • 怎么样做网站赚钱医药网站怎么做
  • 手机如何建免费网站网站建设温州
  • 宝安营销型网站建设公司网站用什么开发软件做
  • 酒店类的电影网站模板网站设计排名北京
  • 网站开发成功案例网络推广网站排行榜
  • 网站使用条款模板松江集团网站建设