IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 数据结构与算法 -> 力扣——算法入门计划第一天 -> 正文阅读

[数据结构与算法]力扣——算法入门计划第一天

目录

🍕题目一

🍔思路?

🍟代码

🍕 题目二

🍔思路:?

🍟代码?

?🍕题目三

🍔思路:

🍟代码:?


🍕题目一

704. 二分查找

🍔思路?

从中间开始查找,因为列表是有序的(而且是升序的),

目标值小于中间的数,就向左走(左边的数小)

目标值大于中间的数,就向右走(右边的数大)

🍟代码

class Solution:
    def search(self, nums: List[int], target: int) -> int:
        left = 0
        right = len(nums)-1
        while left<=right:
            mid = (left+right)//2
            if target == nums[mid]:
                return mid
            elif target<nums[mid]:
                right=mid-1
            else:
                left = mid+1


        return -1

l = [-1,0,3,5,9,12]
s = Solution()
print(s.search(l,5))

🍕 题目二

278. 第一个错误的版本

🍔思路:?

先一个左指针,一个右指针,区间从【1到n】????????注意这个细节,决定返回什么

(1)while(l<=r): 判断左指针是否小于右指针(就是mid值是否有效)

(2)if(isBadVersion(mid)):
? ? ? ? ? ? ? ? r=mid - 1

意思是mid值比目标值大了或者刚刚好相同,右指针向左移动

(3)else:
? ? ? ? ? ? ? ? l=mid + 1

其他情况就是mid值小于目标值左指针向左移动

(4)最后返回 左指针的值是因为

? ? ?具体看这种特殊情况??? ?因为当mid值小于目标值,是左指针动,所以返回左指针

🍟代码?

# The isBadVersion API is already defined for you.
# @param version, an integer
# @return an integer
# def isBadVersion(version):

class Solution:
    def firstBadVersion(self, n):
        """
        :type n: int
        :rtype: int
        """
        l=1
        r=n
        while(l<=r):
            mid=(l+r)//2
            if(isBadVersion(mid)):
                r=mid - 1
            else:
                l=mid + 1
        return l





?🍕题目三

35. 搜索插入位置

🍔思路:

(1)while(l < r)? ?因为采用左闭右开区间[left,right)右开, 所以不能有=,区间不存在

(2)?

if nums[mid] < target:???????? ????????# 中点小于目标值,在右侧,可以得到相等位置
? ? ? ? ? ? ? ? l = mid + 1? ????????????????? # 左闭,所以要+1

(3)right = mid? ? ? ?????????????????# 右开,真正右端点为mid-1

(4)return left

# 此算法结束时保证left = right,返回谁都一样

和上面的第二题算法不同哦,因为区间选取不同

第二题,只能返回左指针

🍟代码:?

class Solution:
    def searchInsert(self, nums: List[int], target: int) -> int:
        l = 0
        r = len(nums)
        while(l < r):
            mid = (l+r)//2
            if(nums[mid]<target):
                l = mid + 1
            else:
                r = mid
        return l

  数据结构与算法 最新文章
【力扣106】 从中序与后续遍历序列构造二叉
leetcode 322 零钱兑换
哈希的应用:海量数据处理
动态规划|最短Hamilton路径
华为机试_HJ41 称砝码【中等】【menset】【
【C与数据结构】——寒假提高每日练习Day1
基础算法——堆排序
2023王道数据结构线性表--单链表课后习题部
LeetCode 之 反转链表的一部分
【题解】lintcode必刷50题<有效的括号序列
上一篇文章      下一篇文章      查看所有文章
加:2022-01-16 13:19:22  更:2022-01-16 13:19:26 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/10 16:47:59-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码