网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
//2表示整除2向下取整
mid = left + (right - left) // 2
if nums[mid] == target:
return mid
如果大于目标右指针往左移 这样中值会变小
elif nums[mid] > target:
right = mid - 1
小于目标左指针往右移
else:
left = mid + 1
没找到返回-1
return -1
思路
–
二分查找必须要在数据有序的条件下进行。左右指针分别位于数组左右边界,中值处于左右指针中点的位置,我们查找元素是依靠中值查找。决定中值的唯一条件就是左右指针的值。当中值与目标值不相等时,根据中值与目标值的大小判断进行移动左指针或右指针缩减范围。重复上述操作,直到找到元素或左右指针重合为止。
重合:当右指针为目标值时,左指针必须与右指针重合中值才能与目标值匹配,因此while条件必须是小于等于。
复杂度
时间复杂度:while循环的次数 -> O (log n)
空间复杂度:仅存在临时辅助变量left,right,mid -> O(1)
冒泡排序
====
模板
–
从小到大排序
def bubble_sort(nums):
重复N-1次即可完成全部排序
for i in range(1, len(nums)):
每进行一次循环都交换出一个最大的数排在后面
因为最后面的数已经排好序了,所以不用全部遍历比较
i不从0开始是防止j+1越界
for j in range(len(nums)-i):
如果前者值大于后者,那么交换他两的值
if nums[j] > nums[j+1]:
nums[j], nums[j+1] = nums[j+1], nums[j]
思路
–
每次大循环可以交换出一个最大值,进行N-1次交换即可完成排序。(如:若列表只有2个元素,那么进行2-1次交换即可完成排序。),而在小循环中,不断将前后元素相比较交换出更大的元素放在后面。小循环可以根据大循环的次数逐步缩小比较范围,因为后面元素已经排好序了,越靠后越大。
复杂度
时间复杂度:如果一开始就是正序一遍过的话复杂度是O(n),如果一开始是反序(最坏情况)复杂度是O()),综上,总体时间复杂度 -> O())
空间复杂度:仅存在临时辅助变量i,j -> O(1)
快速排序
====
模板
–
def quick_sort(nums, start, end):
递归结束条件
if start >= end:
return
生成左右指针
left = start
right = end
生成一个参考点,将小于中心点的值放在左边,大于中心点的值放在右边
pivot = nums[right]
while left < right:
因为参考点在右边所以先从左指针开始寻找比参考点大的元素放在右侧右指针所指位置
while left < right and nums[left] <= pivot: # 如果想要倒序排序,将此处的<=,改成>=
left += 1
将左指针指向的元素赋值给右指针指向的位置,此时有两种情况,
1.左右指针重合left=right,此时赋值与否元素值都不会改变
2.找出了大于参考点值的元素,将其赋值给右指针指向的位置
nums[right] = nums[left]
移动右指针寻找比参考点小的元素
while left < right and nums[right] >= pivot: # 如果想要倒序排序,将此处的<=,改成>=,两处修改完后即为倒序排序
right -= 1
nums[left] = nums[right]
跳出循环后,左右指针必定指向同一位置 然后将参考点放入两指针重合处
nums[left] = pivot
以相同方法继续排序支点左右两边元素
quick_sort(nums, start, left-1)
quick_sort(nums, left+1, end)
简介
–
快速排序是C.R.A.Hoare于1962年提出的一种划分交换排序。它采用的是一种分治策略,通常称其为分治法(Divide-and-ConquerMethod),是对冒泡排序算法的一种改进。
思路
–
首先确定一个参考点,以及排序的区间。排序区间用两个指针表示,两指针分别位于左右区间。开始分别相向移动左右指针,将小于参考点的值放在左边左指针位置,大于参考点的值放在右边右指针位置。重复上述步骤,直到两指针重合为止。当两指针重合时,两指针左边的值全部都小于参考点的值,右边的值全部都大于参考点的值。然后将参考点的值放在两指针所指位置。最后将支点左右两边元素继续上述步骤进行交换排序,直到剩下一个元素不可再划分为止。当每个元素都不可在划分之时,列表已经排序完毕。
思考
找到符合条件的值后将其放在左指针或右指针的位置,这样做是否会覆盖掉原有的值造成数据丢失?
**不会。**因为一开始我们就确定了一个参考点,这个参考点会记录当前左指针或右指针所指的值(假设参考点记录右指针所指的值),记录后我们称此时右指针所指的值为虚值,因为它已经被记录了,它是否存在都不会影响数据的完整性。这时候它就作为我们数值交换的媒介,媒介在右边,那么就从左边开始移动左指针寻找符合条件的元素覆盖掉虚值。虚值被覆盖掉后左边又生成了一个新的虚值,那么现在就移动右指针寻找符合条件的元素覆盖掉虚值…重复上述步骤,直到两指针重合为止。而两指针所指之处必定是重复元素(虚值),因此可以将参考点放入两指针所指位置。
那么我们就发现了一个特点:如果参考点在左侧要右指针先移动,反之,左指针先移动。
模拟图解
结合思路看图解效果更佳噢!
默认参数
最后
不知道你们用的什么环境,我一般都是用的Python3.6环境和pycharm解释器,没有软件,或者没有资料,没人解答问题,都可以免费领取(包括今天的代码),过几天我还会做个视频教程出来,有需要也可以领取~
给大家准备的学习资料包括但不限于:
Python 环境、pycharm编辑器/永久激活/翻译插件
python 零基础视频教程
Python 界面开发实战教程
Python 爬虫实战教程
Python 数据分析实战教程
python 游戏开发实战教程
Python 电子书100本
Python 学习路线规划
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!