一、查找

1、查找的概念:

2 顺序查找(linear search)

从头找到尾

def linear_search(li,val):
for ind ,v in enumerate(li):
if v==val:
return ind
else:
return None

3 二分查找(binary search):

def binary_search(li,val):
left = 0
right = len(li)-1
while left<=right:
mid = (left+right)/2
if li[mid] == val:
return mid
elif li[mid] >val:
right = mid -1
else:
left = mid + 1
else:
return None

----------------

------------------------------

二、列表排序

1、什么是列表排序

排序:将一组“无序”的记录序列调整为“有序”的记录序列

列表排序:将无序列表变为有序列表

输入:列表

输出:有序列表

升序和降序

内置排序函数

2、常见排序算法介绍

排序的Low B三人组

时间复杂度都是O(n^2)

3、排序算法分析

冒泡排序(Bubble sort) 走n-1趟

第一次外层循环把最大的一个数移到最后;第二次外层循环把第二大的移到最后

每一次内部循环都从索引为0和1的数的比较

基本思想:对比相邻的元素值,如果满足提条件就交换元素值,把较小的元素移动到数组前面,把较大的元素移动到数组后面,这样较小的的元素就像气泡一样从底部上升到顶部

def bubble_sort(li):
for i in range(len(li)-1):# n-1趟
for j in range(len(li)-i-1): # 每一次内部循环需要比较的次数
#
if li[j]>li[j+1]:
li[j],li[j+1] = li[j+1],li[j]
print(li,f'第{i+1}次外部循环 ,内部循环比较次数{len(li)-i-1}') li = [4,2,5,1,7,8,9,3,6]
bubble_sort(li)

-------------------------

def bubble_sort(li):
for i in range(len(li)-1):
for j in range(len(li)-i-1):
if li[j]>li[j+1]:
li[j],li[j+1] = li[j+1],li[j]
# t=li[j]
# li[j]=li[j+1]
# li[j+1]=t
import random
# 列表生成式 L = [x * x for x in range(10)] 生成一个list,长度为1000,里面的元素是可以重复的随机数(范围0-10000)
li = [random.randint(0,10000) for i in range(1000)]
print(li)
bubble_sort(li)
print(li)

---------------------------

3.2 选择排序(select sort)

每一次循环选出最小的一个

基本思想:将指定排序位置与其他数组元素分别对比,如果满足条件就交换元素值,把满足条件的元素与指定的排序位置交换

def select_sort(li):
for i in range(len(li)-1):
min = i
for j in range(min+1,len(li)):
if li[min]>li[j]:
li[min],li[j] = li[j],li[min]
print(li, f'第{i+1}次外部循环 ,内部循环比较次数{len(li)-min-1}') li = [4,2,5,1,7,8,9,3,6]
select_sort(li)
print(li)

li = [3,2,4,1,5,6,8,7,9]
def select_sort_simple(li):
li_new = []
for i in range(len(li)):
min_val = min(li)
li_new.append(min_val)
li.remove(min_val)
return li_new print('select_sort_simple',select_sort_simple(li)) def select_sort(li):
for i in range(len(li)-1):
min_loc = i
for j in range(i+1,len(li)):
if li[j] < li[min_loc]:
min_loc = j
li[i],li[min_loc] = li[min_loc],li[i]
print(li) select_sort(li)

-------------------------------

复杂度:0(n^2)

3.3 插入排序

基本思想:将一个记录插入到已排好序的有序表中,从而得到一个新的,记录数增1的有序表,然后再从剩下的关键字中选取下一个插入对象,反复执行直到整个序列有序。

def insert_sort(li):
for i in range(1,len(li)):
tem = li[i] # 要插入的数
j = i-1 # j指的是手里的牌的下标
while li[j] > tem and j>=0:
li[j+1] = li[j]
j -= 1
li[j+1] = tem
print(li)
li = [3,2,4,1,5,7,9,6,8]
insert_sort(li)
print(li,'最后结果')

插入排序的复杂度:O(n^2)

2 算法查找&排序问题的更多相关文章

  1. Kosaraju 算法查找强连通分支

    有向图 G = (V, E) 的一个强连通分支(SCC:Strongly Connected Components)是一个最大的顶点集合 C,C 是 V 的子集,对于 C 中的每一对顶点 u 和 v, ...

  2. 回朔法/KMP算法-查找字符串

    回朔法:在字符串查找的时候最容易想到的是暴力查找,也就是回朔法.其思路是将要寻找的串的每个字符取出,然后按顺序在源串中查找,如果找到则返回true,否则源串索引向后移动一位,再重复查找,直到找到返回t ...

  3. 数据结构与算法--KMP算法查找子字符串

    数据结构与算法--KMP算法查找子字符串 部分内容和图片来自这三篇文章: 这篇文章.这篇文章.还有这篇他们写得非常棒.结合他们的解释和自己的理解,完成了本文. 上一节介绍了暴力法查找子字符串,同时也发 ...

  4. Java冒泡,快速,插入,选择排序^_^+二分算法查找

    这段时间在学Java,期间学到了一些排序和查找方法.特此写来和大家交流,也方便自己的日后查看与复习. 1.下边是Java的主类: public class Get { public static vo ...

  5. c语言经典算法——查找一个整数数组中第二大数

    题目: 实现一个函数,查找一个整数数组中第二大数. 算法思想: 设置两个变量max1和max2,用来保存最大数和第二大数,然后将数组剩余的数依次与这两个数比较,如果这个数a比max1大,则先将max1 ...

  6. opencv2对读书笔记——使用均值漂移算法查找物体

    一些小概念 1.反投影直方图的结果是一个概率映射,体现了已知图像内容出如今图像中特定位置的概率. 2.概率映射能够找到最初的位置,从最初的位置開始而且迭代移动,便能够找到精确的位置,这就是均值漂移算法 ...

  7. 基础算法-查找:线性索引查找(I)

    前面介绍的几种查找的算法都是基于数据有序的基础上进行的.但是在实际的应用中,很多数据集可能有惊人的数据量,面对这些海量的数据,要保证记录全部按照当中的某个关键字有序,其时间代价是非常昂贵的,所以这种数 ...

  8. 算法——查找排序相关面试题和leetcode使用

    1.给两个字符串s和t,判断t是否为s的重新排列后组成的单词. s = "anagram", t = "nagaram", return true. s = & ...

  9. 数据结构与算法---查找算法(Search Algorithm)

    查找算法介绍 在java中,我们常用的查找有四种: 顺序(线性)查找 二分查找/折半查找 插值查找 斐波那契查找 1)线性查找算法 示例: 有一个数列: {1,8, 10, 89, 1000, 123 ...

随机推荐

  1. PAT 乙级 1064 朋友数(20) C++版

    1064. 朋友数(20) 时间限制 400 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CHEN, Yue 如果两个整数各位数字的和是一样的,则被 ...

  2. 珍藏的数据库SQL基础练习题答案

    自己珍藏的数据库SQL基础练习题答案 一,基本表的定义与删除. 题1: 用SQL语句创建如下三张表:学生(Student),课程表(Course),和学生选课表(SC),这三张表的结构如表1-1到表1 ...

  3. MySQL binlog 企业案例升级版

    需求:1.创建一个数据库 oldboy2.在oldboy下创建一张表t13.插入5行任意数据4.全备5.插入两行数据,任意修改3行数据,删除1行数据6.删除所有数据7.再t1中又插入5行新数据,修改3 ...

  4. 计划任务at、crontab

    at一次性计划任务 格式: at + 时间 命令 安装at # yum install at -y 如果执行at命令时,出现一下情况 Can't open /var/run/atd.pid to si ...

  5. 在线学习和在线凸优化(online learning and online convex optimization)—在线凸优化框架3

    近年来,许多有效的在线学习算法的设计受到凸优化工具的影响. 此外,据观察,大多数先前提出的有效算法可以基于以下优雅模型联合分析: 凸集的定义: 一个向量 的Regret定义为: 如前所述,算法相对于竞 ...

  6. TensorFlow安装教程(ubuntu 18.04)

    此教程的硬件条件: 1.Nvidia GPU Geforce390及以上 2.Ubuntu 18.04操作系统 3.Anaconda工具包 如果python版本为3.7及以上,使用如下命令降级到3.6 ...

  7. 第6章 静态路由和动态路由(4)_OSPF动态路由协议

    6. OSPF动态路由协议 6.1 OSPF协议(Open Shortest Path First,OSPF开放式最短路径优先协议) (1)通过路由器之间通告链路的状态来建立链路状态数据库,网络中所有 ...

  8. Delphi获取本机的MAC地址

    Delphi获取本机的MAC地址: uses   NB30; function GetAdaPterInfo(lana: Char): string; var   Adapter: TAdapterS ...

  9. day16(软件开发目录规范)

    模块的使用01 模块的循环导入问题 解决方案一: 把循环导入的语句放到名字定义的后面 解决方案二: 将循环导入语句放到函数内(先定义确定名称空间)02 区分python文件的两种用途 #当文件被执行时 ...

  10. java多线程的认识

    [线程定义]   定义:线程(英语:thread)是操作系统能够进行运算调度的最小单位.它被包含在进程之中,是进程中的实际运作单位.一条线程指的是进程中一个单一顺序的控制流,一个进程中可以并发多个线程 ...