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

做网站要懂什么编程免费网站推广网站破解版

做网站要懂什么编程,免费网站推广网站破解版,做网站源码要给客户嘛,优化建议怎么写文章目录 一,排序算法时间复杂度比较二,插入排序三,冒泡排序四,快速排序五,堆排序六,二分归并排序 一,排序算法时间复杂度比较 算法最坏情况下平均情况下插入排序O(n )O(n)冒泡排序O(n)O(n)快速…

文章目录

  • 一,排序算法时间复杂度比较
  • 二,插入排序
  • 三,冒泡排序
  • 四,快速排序
  • 五,堆排序
  • 六,二分归并排序

一,排序算法时间复杂度比较

算法最坏情况下平均情况下
插入排序O(n² )O(n²)
冒泡排序O(n²)O(n²)
快速排序O(n²)O(nlogn)
堆排序O(nlogn)O(nlogn)
二分归并排序O(nlogn)O(nlogn)

二,插入排序

假设原始序列为:[5,7,1,3,6,2,4]
首先假设第一个元素5已经排好,然后插入第二个元素7但是7比5大所以7放在5的右边,接着是第三个元素1,1比7小所以再7左边并且1比5小所以放在5的左边。第四个元素3于7比较比7小在7左边并且比5小所以在5左边但是3比1小所以插入到1和5之间,其他的类似。。。。

原始序列5713624
插入零次5713624
插入一次5713624
插入二次1573624
插入三次1357624
插入四次1356724
插入五次1235674
插入六次1234567
a = [5,7,1,3,6,2,4]
n = len(a)
for i in range(1, n):key = a[i]  # 当前待插入元素j = i - 1  # 已排序部分的最后一个元素的索引while j >= 0 and a[j] > key:a[j + 1] = a[j]  # 向后移动元素j -= 1a[j + 1] = key  # 插入元素到正确位置
print(a)
#[1, 2, 3, 4, 5, 6, 7]

三,冒泡排序

假设原始序列为:[5,7,1,3,6,2,4]
首先5和7比较,5比7小不交换顺序,7和1比较,7比1大交换顺序,7和3比较,7比3大交换顺序,7和6比较7比6大交换顺序,7和4比较,7比4大交换顺序。以此类推

原始序列5713624
冒泡一次5136247
冒泡二次1352467
冒泡三次1324567
冒泡四次1234567
a = [5,7,1,3,6,2,4]
n = len(a)
for i in range(n):for j in range(0, n-i-1):if a[j] > a[j+1]:a[j], a[j+1] = a[j+1], a[j]
print(a)
#[1, 2, 3, 4, 5, 6, 7]

四,快速排序

假设原始序列为:[5,7,1,3,6,2,4]
首先以第一个元素5为划分的标准,从前面找第一个比5大的从后面找第一个比5小的交换位置,然后再找下一个比大的和比5小的交换位置。第二次交换是发生在两个相邻的元素之间做的所以说2前面的都比5小,6后面的都比5大所以2的位置是第一个元素5的位置,然后交换2和5的位置,这样5的位置就定下来了,再分别对两边递归调用同样的方法。

原始序列5713624
交换一次5413627
交换二次5413267
划分2413567
递归运行2413567
a = [5,7,1,3,6,2,4]
def fast_sort(a):if len(a) <= 1:return abasis = a[0]left_num  = [i for i in a[1::] if i < basis]middle    = [i for i in a     if i == basis]right_num = [i for i in a[1::] if i > basis]return fast_sort(left_num) + middle + fast_sort(right_num)
print(fast_sort(a))
#[1, 2, 3, 4, 5, 6, 7]

五,堆排序

pass

六,二分归并排序

它将待排序的列表递归地分成两个子列表,直到每个子列表只包含一个元素。然后,将这些子列表按照顺序合并,形成一个有序的列表。
假设原始序列为:[5,7,1,3,6,2,4]
首先先把序列一份为二 (标注和没标注的),然后对每个子列里面也分别进行二分归并排序,然后把已经排好的子数合并(两个序列的首元素比较哪个小就把哪个拿走,知道一个数组空了就把另一个数组全部接在后面)。

原始序列5713624
归分5413627
递归排序1345267
开始组合1345267
345267
新数组1
34567
新数组12
4567
新数组123
567
新数组1234
67
新数组12345
新数组1234567
a = [5, 7, 1, 3, 6, 2, 4]def merge_sort(arr):if len(arr) <= 1:return arrmid = len(arr) // 2left = arr[:mid]right = arr[mid:]left = merge_sort(left)right = merge_sort(right)return merge(left, right)def merge(left, right):merged = []i = j = 0while i < len(left) and j < len(right):if left[i] <= right[j]:merged.append(left[i])i += 1else:merged.append(right[j])j += 1while i < len(left):merged.append(left[i])i += 1while j < len(right):merged.append(right[j])j += 1return mergedprint(merge_sort(a))
http://www.hrbkazy.com/news/38424.html

相关文章:

  • 长春最新通告11月2日起seo网站关键词排名优化
  • 长沙 网站设计 公司价格电商网页制作教程
  • 成都网站开发工作室关键词seo排名优化如何
  • 高端品牌网站建设制作多少钱百度搜索引擎排名
  • 苹果手机如何做网站服务器上海网站推广服务
  • wordpress新站5天收录营销推广ppt
  • 百度联盟做网站赚钱以图搜图
  • 记录网站建设的基本步骤简述seo的概念
  • 济宁官方网站网站流量分析报告
  • 石家庄网站定制没干过网络推广能干吗
  • 网站名称需要用注册吗市场调研报告模板
  • 自助贸易网免费网站排名优化软件
  • 湖南省新闻最新消息十条seo搜索引擎优化ppt
  • 如何用免费服务器做网站百度手机导航官方新版
  • 做英雄联盟网站的图片素材口碑营销的主要手段有哪些
  • 广东省建设监理协会网站 首页可以看封禁网站的浏览器
  • 网站设计公司 无锡培训网登录入口
  • 做视频赚钱的网站百度网页版首页
  • 威海建设信息网站海口网站建设
  • 做网站需要学啥免费推广app平台有哪些
  • 惠州城乡和住房建设局网站黄页推广引流网站
  • 做博客的网站网站模板之家官网
  • 郑州网站建设贝斯特新媒体运营岗位职责
  • 网站建设jiq什么是网络营销的核心
  • 徐州网站推广竞价托管推广公司
  • 网站和自媒体都可以做360收录查询
  • 现在网站建设还用测浏览器吗产品推广计划书怎么写
  • 基层政府建设管理网站千万别手贱在百度上搜这些词
  • 网站上放百度地图网络推广的途径有哪些
  • 东营 微信网站建设自己建网站需要钱吗