感谢每一个认真阅读我文章的人,看着粉丝一路的上涨和关注,礼尚往来总是要有的:
① 2000多本Python电子书(主流和经典的书籍应该都有了)
② Python标准库资料(最全中文版)
③ 项目源码(四五十个有趣且经典的练手项目及源码)
④ Python基础入门、爬虫、web开发、大数据分析方面的视频(适合小白学习)
⑤ Python学习路线图(告别不入流的学习)
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
二分查找
模板
思路
复杂度
冒泡排序
模板
思路
复杂度
快速排序
模板
简介
思路
思考
模拟图解
默认参数
复杂度
想说的话
二分查找
====
模板
–
def binary_search(nums, target):
二分查找前提是数据是要有序的
nums.sort()
左指针指向第一个元素
left = 0
右指针指向最后一个元素
right = len(nums) - 1
注意是小于等于
while left <= right:
//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):
递归结束条件
最后
不知道你们用的什么环境,我一般都是用的Python3.6环境和pycharm解释器,没有软件,或者没有资料,没人解答问题,都可以免费领取(包括今天的代码),过几天我还会做个视频教程出来,有需要也可以领取~
给大家准备的学习资料包括但不限于:
Python 环境、pycharm编辑器/永久激活/翻译插件
python 零基础视频教程
Python 界面开发实战教程
Python 爬虫实战教程
Python 数据分析实战教程
python 游戏开发实战教程
Python 电子书100本
Python 学习路线规划
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!