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

先备案 做网站seo建站网络公司

先备案 做网站,seo建站网络公司,唯品会网站开发技术分析,电子商务网站建设预算前言 今天学习了一句话“自己如果不努力,屎都吃不上热乎的”,话糙理不糙,与君共勉 35. 搜索插入位置 - 力扣(LeetCode) 二分查找 class Solution:def searchInsert(self, nums: List[int], target: int) -> int:n…

前言

  • 今天学习了一句话“自己如果不努力,屎都吃不上热乎的”,话糙理不糙,与君共勉

35. 搜索插入位置 - 力扣(LeetCode)

  • 二分查找

    • class Solution:def searchInsert(self, nums: List[int], target: int) -> int:n = len(nums)l, r = 0, n - 1while l <= r:              # 左闭右闭mid = l + (r - l) // 2if nums[mid] == target:return midelif nums[mid] < target:l = mid + 1else:r = mid - 1return r + 1   # 应该插入的位置

74. 搜索二维矩阵 - 力扣(LeetCode)

  •  二分查找

    • class Solution:def searchMatrix(self, matrix: List[List[int]], target: int) -> bool:m, n = len(matrix), len(matrix[0])l, r = 0, m * n - 1while l <= r:mid = l + (r - l) // 2row = mid // n  # 转化成矩阵中的行坐标col = mid % n   # 转化成矩阵中的列坐标print(mid, row, col)if matrix[row][col] < target: l = mid + 1elif matrix[row][col] > target:r = mid - 1else:return Truereturn False

34. 在排序数组中查找元素的第一个和最后一个位置 - 力扣(LeetCode)

  • 二分查找(左右边界)

    • class Solution:def searchRange(self, nums: List[int], target: int) -> List[int]:# 寻找[target,...,target]的左边界def leftBorder(nums, target):l, r = 0, len(nums) - 1while l <= r:mid = l + (r - l) // 2if nums[mid] >= target:r = mid - 1else:l = mid + 1return l# 寻找[target,...,target]的右边界def rightBorder(nums, target):l, r = 0, len(nums) - 1while l <= r:mid = l + (r - l) // 2if nums[mid] <= target:l = mid + 1else:r = mid - 1return rl_Border = leftBorder(nums, target)r_Border = rightBorder(nums, target)if l_Border <= r_Border:return [l_Border, r_Border]else:  # 排除找不到target的情况return [-1, -1]
  • 二分查找(单边界滑动)

    • class Solution:def searchRange(self, nums: List[int], target: int) -> List[int]:# 寻找[target,...,target]的左边界def leftBorder(nums, target):l, r = 0, len(nums) - 1while l <= r:mid = l + (r - l) // 2if nums[mid] >= target:r = mid - 1else:l = mid + 1return ln = len(nums)l_Border = leftBorder(nums, target)# 处理特殊情况,找不到targetif l_Border == n or nums[l_Border] != target: return [-1,-1]# 允许范围内,右边界向右滑动r_Border = l_Borderwhile r_Border + 1 <= n - 1 and nums[r_Border+1] == target:r_Border += 1return [l_Border, r_Border]

33. 搜索旋转排序数组 - 力扣(LeetCode)

  • 二分查找(寻找有序)

    • class Solution:def search(self, nums: List[int], target: int) -> int:n = len(nums)l, r = 0, n - 1while l <= r:mid = l + (r - l) // 2# mid左侧(包含mid)为有序部分,一个元素nums[0]==nums[mid]也有序,所以要<=if nums[0] <= nums[mid]:if nums[0] <= target < nums[mid]:r = mid - 1elif target == nums[mid]:return midelse:l = mid + 1# mid右侧(包含mid)为有序部分else:if nums[mid] < target <= nums[n - 1] :l = mid + 1elif target == nums[mid]:return midelse:r = mid - 1          return -1

153. 寻找旋转排序数组中的最小值 - 力扣(LeetCode)

  • 二分查找(寻找无序)

    • class Solution:def findMin(self, nums: List[int]) -> int:l, r = 0, len(nums) - 1while l <= r:mid = l + (r - l) // 2# 左边有序,右边无序,去右边找if nums[0] <= nums[mid]:  # <=,考虑[2,1]中l=mid情况,要往右找if mid > 0 and nums[mid-1] > nums[mid]:  # 异常递减值return nums[mid]else:l = mid + 1# 右边有序,左边无序,去左边找else:if mid > 0 and nums[mid-1] > nums[mid]:  # 异常递减值return nums[mid]else:r = mid - 1return nums[0]  # 找不到说明无旋转,nums[0]就是最小# 简洁优化,边界难处理
      class Solution:def findMin(self, nums: List[int]) -> int:l, r = 0, len(nums) - 1if nums[l] <= nums[r]:  # 本身有序返回第一个return nums[l]while l <= r:mid = l + (r - l) // 2if nums[0] <= nums[mid]:  # <=,考虑[2,1]中l=mid情况,要往右找l = mid + 1           # 右边无序往右找else:                     r = mid - 1           # 左边无序往左找return nums[l]

4. 寻找两个正序数组的中位数 - 力扣(LeetCode)

  • 困难题,要递归找两个有序数组的第k大数,看思路讲解和代码实现
  • class Solution:def findMedianSortedArrays(self, nums1: List[int], nums2: List[int]) -> float:"""给定两个排好序的数组,求他们合并后的第k大数"""def findK(nums1, nums2, k):if len(nums1) == 0:      # 其中一个为空就返回另一个的第k大,对应下标k-1return nums2[k-1]if len(nums2) == 0:return nums1[k-1]  if k == 1:               # 第1大就比较头两个数return min(nums1[0], nums2[0])k1 = min(k//2, len(nums1))  # 划分给nums1的数量,可能不够k2 = min(k-k1, len(nums2))  # 剩余给nums2的数量,可能不够if nums1[k1-1] < nums2[k2-1]:     # 小的数不可能是第k大了,删除后递归去下一层return findK(nums1[k1:], nums2, k-k1)else:  # 由于可能有不够的现象,相等不意味着就是第k大,还要继续分割return findK(nums1, nums2[k2:], k-k2)size = len(nums1) + len(nums2)if size % 2 == 0:  # 偶数left = findK(nums1, nums2, size // 2)       # 10就是找第5right = findK(nums1, nums2, size // 2 + 1)  # 10就是找第6res = (left + right) / 2else:              # 奇数res = findK(nums1, nums2, size // 2 + 1)    # 11就是找第6return res

后言

  • 二分实现和记模板不难,主要是要处理好边界,多在草稿上演算一下就行 
http://www.tj-hxxt.cn/news/85380.html

相关文章:

  • 昆明网站建站上海好的seo公司
  • 个人网站设计论文pptseo的中文意思是什么
  • 东莞专业网站建设关键词优化的方法有哪些
  • 外贸公司网站源码武汉seo关键字优化
  • 淮南公司做网站网络营销工具包括
  • 毕业设计网站代做多少钱单个药品营销策划方案
  • 北京网站制作推广国外外链平台
  • 做数据分析网站百度识图软件
  • 网站备案号是什么意思今日油价92汽油价格调整最新消息
  • 网站建设网页设计师知乎推广
  • 网站备案作用cps推广联盟
  • 新建网站怎么保存百度推广怎么收费
  • 抖音小程序官网seozou是什么意思
  • 佛山网红打卡景点大全排名榜上海搜索seo
  • 做公司 网站建设福建seo排名
  • 局域网网站制作卡点视频免费制作软件
  • 免费永久网站注册新闻头条今天最新消息
  • 北京优化靠谱的公司亚马逊排名seo
  • 信阳做网站 汉狮网络爱站网 关键词挖掘工具站
  • 在网站的标题上怎么做图标百度高级搜索引擎入口
  • 付费腾讯企业邮箱入口如何做关键词优化
  • 招牌图片效果图设计制作企业网站优化解决方案
  • 去年做那个网站致富网站设计软件
  • 旅游商务网站开发邯郸网站seo
  • 东莞有哪些好的网站建设公司提高工作效率的措施
  • 贴吧网站开发需求分析seo投放
  • 做网站专业服务北京网站优化推广公司
  • 大黔门官方网站建设世界军事新闻
  • 妇联网站建设方案谷歌优化培训
  • 网站制作素材图片天津百度推广公司电话