• 01 算法基本概念与递归;

  • 02 二分查找与LOW B三人组

  • 03 快速排序

  • 04 归并排序

01 算法基本概念与递归;

1.1 算法概念

1.2 复习:递归

1.3 时间复杂度

1.4 空间复杂度

1.5 递归

def func3(n):
if n > 0:
func3(n - 1)
print(n) func3(5) def text(n):
if n > 0:
print('抱着', end='')
text(n - 1)
print('的我', end='')
else:
print("我的小鲤鱼", end='') text(5) # 汉诺塔问题
def hanoi(n, A, B, C):
if n >0:
# n个盘子从A经过B移动到C;
hanoi(n - 1, A, C, B)
print("%s->%s" % (A, C))
hanoi(n - 1, B, A, C) hanoi(3, "A", "B", "C")

1.6 汉诺塔问题(递归的经典)

02 二分查找与LOW B三人组

2.1 列表查找;

2.2  顺序查找;

2.3 二分查找(本身有序);

import time

def cal_time(func):
def wrapper(*args, **kwargs):
t1 = time.time()
result = func(*args, **kwargs)
t2 = time.time()
print("%s running time:%s secs." % (func.__name__, t2 - t1))
return result return wrapper # 线性查找;
@cal_time
def binary_search(li, val):
low = 0
high = len(li) - 1 while low <= high:
mid = (low + high) // 2
if li[mid] > val:
high = mid - 1
elif li[mid] < val:
low = mid + 1
else:
return mid
else:
return None # 二分查找;
@cal_time
def linear_search(li, val):
try:
i = li.index(val)
return i
except:
return None li = list(range(0, 100000000, 2))
times = binary_search(li, 9000006)
print(times)
times1 = linear_search(li, 9000006)
print(times1)

2.4 列表排序;

  2.4.1 列表排序

  • 将无序列表变成有序列表

  2.4.2 应用场景

  • 各种榜单
  • 各种表格
  • 给二分查找使用
  • 给其他算法使用

  2.4.3 输入:无序列表

  2.4.4 输出:有序列表

  2.4.5 升序与降序

  2.4.6 排序LOW B 三人组

  • 冒泡排序
  • 选择排序
  • 插入排序

  2.4.7 排序NB三人组

  • 快速排序
  • 堆排序
  • 归并排序

  2.4.8 没什么人用的排序

  • 基数排序
  • 希尔排序
  • 桶排序
  • 计数排序

  2.4.9 算法关键点

  • 有序区域
  • 无序区域
  • 冒泡算法优化思路——如果冒泡排序中执行一趟而没有交换,则列表已经是有序的状态,可以直接结束算法;

buddle_sort.py;

from cal_time import cal_time

@cal_time
def buddle_sort(li):
for i in range(0, len(li) - 1):
# i 是表示第i趟,此时有序区有i个数;
for j in range(0, len(li) - i - 1):
if li[j] > li[j + 1]:
li[j], li[j + 1] = li[j + 1], li[j] import random li = list(range(10000))
random.shuffle(li)
buddle_sort(li)
print(li)

二分查找优化算法:

buddle_sort_opt.py;

from cal_time import cal_time

@cal_time
def buddle_sort(li):
for i in range(0, len(li) - 1):
exchange = False
# i 是表示第i趟,此时有序区有i个数;
for j in range(0, len(li) - i - 1):
if li[j] > li[j + 1]:
li[j], li[j + 1] = li[j + 1], li[j]
exchange = True
if not exchange:
return import random li = list(range(10000))
# random.shuffle(li)
buddle_sort(li)
print(li)

cal_time.py;

import time

def cal_time(func):
def wrapper(*args, **kwargs):
t1 = time.time()
result = func(*args, **kwargs)
t2 = time.time()
print("%s running time:%s secs." % (func.__name__, t2 - t1))
return result return wrapper

2.5 选择排序思路

  • 代码关键点——无序区域、最小数的位置;

2.6 插入排序;

03 快速排序

04 堆排序

05 归并排序

Python-S9-Day128——算法基础Algorithm的更多相关文章

  1. 腾讯2017年暑期实习生编程题【算法基础-字符移位】(C++,Python)

     算法基础-字符移位 时间限制:1秒 空间限制:32768K 题目: 小Q最近遇到了一个难题:把一个字符串的大写字母放到字符串的后面,各个字符的相对位置不变,且不能申请额外的空间. 你能帮帮小Q吗? ...

  2. Python算法基础

    一.简介 定义和特征 定义:算法(Algorithm)是指解题方案的准确而完整的描述,是一系列解决问题的清晰指令,算法代表着用系统的方法描述解决问题的策略机制.也就是说,能够对一定规范的输入,在有限时 ...

  3. Python 迭代器&生成器,装饰器,递归,算法基础:二分查找、二维数组转换,正则表达式,作业:计算器开发

    本节大纲 迭代器&生成器 装饰器  基本装饰器 多参数装饰器 递归 算法基础:二分查找.二维数组转换 正则表达式 常用模块学习 作业:计算器开发 实现加减乘除及拓号优先级解析 用户输入 1 - ...

  4. Python之算法基础

    1>递归相关: 递归:递归算法是一种直接或间接地调用自身算法的过程,在计算机编写程序中,递归算法对解决一大类问题是十分有效的,它往往使算法的描述简洁而且                   易于 ...

  5. Python数据结构与算法--算法分析

    在计算机科学中,算法分析(Analysis of algorithm)是分析执行一个给定算法需要消耗的计算资源数量(例如计算时间,存储器使用等)的过程.算法的效率或复杂度在理论上表示为一个函数.其定义 ...

  6. python数据结构与算法

    最近忙着准备各种笔试的东西,主要看什么数据结构啊,算法啦,balahbalah啊,以前一直就没看过这些,就挑了本简单的<啊哈算法>入门,不过里面的数据结构和算法都是用C语言写的,而自己对p ...

  7. Python数据结构与算法--List和Dictionaries

    Lists 当实现 list 的数据结构的时候Python 的设计者有很多的选择. 每一个选择都有可能影响着 list 操作执行的快慢. 当然他们也试图优化一些不常见的操作. 但是当权衡的时候,它们还 ...

  8. python 小白(无编程基础,无计算机基础)的开发之路 day1

    本节内容 Python介绍 发展史 Python 2 or 3? 安装 Hello World程序 变量 用户输入 模块初识 .pyc是个什么鬼? 数据类型初识 数据运算 表达式if ...else语 ...

  9. 解读Raft(一 算法基础)

    最近工作中讨论到了Raft协议相关的一些问题,正好之前读过多次Raft协议的那paper,所以趁着讨论做一次总结整理. 我会将Raft协议拆成四个部分去总结: 算法基础 选举和日志复制 安全性 节点变 ...

随机推荐

  1. uvm_svcmd_dpi——DPI在UVM中的实现(二)

    UVM中有需要从cmmand line 输入参数的需求,所有uvm_svcmd_dpi.svh和uvm_svcmd_dpi.cc 文件就是实现功能. uvm_svcmd_dpi.svh的源代码如下,我 ...

  2. python 多线程 生产者消费者

    import threading import time import logging import random import Queue logging.basicConfig(level=log ...

  3. java Vamei快速教程15 IO基础

    作者:Vamei 出处:http://www.cnblogs.com/vamei 欢迎转载,也请保留这段声明.谢谢! 计算机最重要的功能是处理数据.一个有用的计算机语言需要拥有良好的IO功能,以便让未 ...

  4. php之header的不同用法

    1.header()函数的作用是:发送一个原始 HTTP 标头[Http Header]到客户端. header(string,replace,http_response_code) /*string ...

  5. 2018.10.24 NOIP2018模拟赛 解题报告

    得分: \(100+0+100=200\)(\(T2\)悲惨爆\(0\)) \(P.S.\)由于原题是图片,所以我没有上传题目描述,只有数据. \(T1\):query(点此看题面) 熟悉主席树的人都 ...

  6. SEO人士一定要了解的搜索引擎惩罚原则

       SEO人士一定要了解的搜索引擎惩罚原则 SEO 的人一般都知道SEO分为白帽,黑帽,甚至还有灰帽.简单说,如果你熟读过谷歌网站质量指南,就可以了解,符合搜索引擎质量规范并且符合用户体验的SEO ...

  7. python_8_guess

    #python3和2都可以 #方法1 age_of_oldboy=56 count=0 while True: if count==3: break guess_age=int(input('gues ...

  8. ReentrantReadWriteLock的使用

    ReentrantReadWriteLock的规则是: 多线程情况下:读-写互斥.写-读互斥.写-写互斥.读-读共享 验证“读-写互斥.写-读互斥.写-写互斥.读-读共享” //单个线程 读-读 不互 ...

  9. java设计模式——单例模式(三)

    容器单例模式 之前学习Structs2,Spring框架时,经常会听到单例,多例.虽然这与单例模式不太一样,但是都很类似.在程序运行的时候,就加载所有的实例,然后用的时候直接取出 看下面代码: /** ...

  10. 表格和网页ico图标

    表格: 表格格式: <table> <tr> 表格的行 <th >表头</th> <th>表头 </th> </tr> ...