力扣——算法入门计划第一天

简介: 力扣(LeetCode)是领扣网络旗下专注于程序员技术成长和企业技术人才服务的品牌。源自美国硅谷,力扣为全球程序员提供了专业的IT技术职业化提升平台,有效帮助程序员实现快速进步和长期成长。 此外,力扣(LeetCode)致力于解决程序员技术评估、培训、职业匹配的痛点,逐步引领互联网技术求职和招聘迈向专业化。

目录

🍕题目一

🍔思路

🍟代码

🍕 题目二

🍔思路:

🍟代码

🍕题目三

🍔思路:

🍟代码:


🍕题目一

704. 二分查找

image.gifimage.png

🍔思路

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

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

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

🍟代码

classSolution:
defsearch(self, nums: List[int], target: int) ->int:
left=0right=len(nums)-1whileleft<=right:
mid= (left+right)//2iftarget==nums[mid]:
returnmideliftarget<nums[mid]:
right=mid-1else:
left=mid+1return-1l= [-1,0,3,5,9,12]
s=Solution()
print(s.search(l,5))

image.gif

image.gifimage.png

🍕 题目二

278. 第一个错误的版本

image.png

🍔思路:

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

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

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

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

(3)else:

               l=mid + 1

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

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

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

动态演示如下

https://ucc.alicdn.com/images/user-upload-01/7722336420314a088b59ad12e6936cbc.gifimage.gif

🍟代码

# 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

image.gif

🍕题目三

35. 搜索插入位置

image.gifimage.png

🍔思路:

(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


image.png

image.png

相关文章
|
1天前
|
缓存 算法 C语言
数据结构与算法⑧(第三章_上)栈的概念和实现(力扣:20. 有效的括号)
数据结构与算法⑧(第三章_上)栈的概念和实现(力扣:20. 有效的括号)
4 0
|
6天前
|
存储 算法
Leetcode 30天高效刷数据结构和算法 Day1 两数之和 —— 无序数组
给定一个无序整数数组和目标值,找出数组中和为目标值的两个数的下标。要求不重复且可按任意顺序返回。示例:输入nums = [2,7,11,15], target = 9,输出[0,1]。暴力解法时间复杂度O(n²),优化解法利用哈希表实现,时间复杂度O(n)。
22 0
|
6天前
|
存储 机器学习/深度学习 算法
|
6天前
|
存储 缓存 算法
C++从入门到精通:4.6性能优化——深入理解算法与内存优化
C++从入门到精通:4.6性能优化——深入理解算法与内存优化
|
6天前
|
存储 算法 程序员
C++从入门到精通:2.2.1标准库与STL容器算法深度解析
C++从入门到精通:2.2.1标准库与STL容器算法深度解析
|
6天前
|
算法
代码随想录算法训练营第六十天 | LeetCode 84. 柱状图中最大的矩形
代码随想录算法训练营第六十天 | LeetCode 84. 柱状图中最大的矩形
24 3
|
6天前
|
存储 算法
代码随想录算法训练营第五十九天 | LeetCode 739. 每日温度、496. 下一个更大元素 I
代码随想录算法训练营第五十九天 | LeetCode 739. 每日温度、496. 下一个更大元素 I
23 1
|
6天前
|
算法
代码随想录算法训练营第五十七天 | LeetCode 739. 每日温度、496. 下一个更大元素 I
代码随想录算法训练营第五十七天 | LeetCode 739. 每日温度、496. 下一个更大元素 I
18 3
|
6天前
|
算法
代码随想录算法训练营第五十六天 | LeetCode 647. 回文子串、516. 最长回文子序列、动态规划总结
代码随想录算法训练营第五十六天 | LeetCode 647. 回文子串、516. 最长回文子序列、动态规划总结
34 1
|
6天前
|
算法
代码随想录算法训练营第五十五天 | LeetCode 583. 两个字符串的删除操作、72. 编辑距离、编辑距离总结
代码随想录算法训练营第五十五天 | LeetCode 583. 两个字符串的删除操作、72. 编辑距离、编辑距离总结
26 1