• 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. Python学习笔记-day1(if流程控制)

    在python中,流程控制语句为强制缩进(4空格) if username=='lmc' and password=='123456': print('Welcome User {name} logi ...

  2. amap -bq 192.168.5.9 80 3306

    amap -bq 192.168.5.9 80 3306 查看运行在指定端口上运行的服务

  3. python property用法

    参考 http://openhome.cc/Gossip/Python/Property.html http://pyiner.com/2014/03/09/Python-property.html ...

  4. jquery-weui picker组件实现只选择年月

    var date = new Date() var month = date.getMonth()+1 //获取当前月份 $('#selectTime').picker({ toolbarTempla ...

  5. linux 命令——7 mv(转)

    mv命令是move的缩写,可以用来移动文件或者将文件改名(move (rename) files),是Linux系统下常用的命令,经常用来备份文件或者目录. 1.命令格式: mv [选项] 源文件或目 ...

  6. 01_14_Struts2_结果类型_result_type

    01_14_Struts2_结果类型_result_type 1. result类型 result类型 说明 dispatcher 默认服务端转发jsp chain 服务端action转发 redir ...

  7. tomcat的启动和部署

    方法/步骤 1 一.安装JDK和Tomcat 1,安装JDK:直接运行jdk-7-windows-i586.exe可执行程序,默认安装即可. 备注:路径可以其他盘符,不建议路径包含中文名及特殊符号. ...

  8. Java如何将十六进制数转换为十进制数的自编程序

    package com.swift;//所属包 import java.util.Scanner;//导入扫描器 public class Hex2Decimal { public static vo ...

  9. Lepus天兔数据库监控系统安装配置

    [root@redis01 ~]# cd /opt/[root@redis01 opt]# wget https://www.apachefriends.org/xampp-files/5.6.36/ ...

  10. Python导入模块方法

    import module_name 导入整个模块 from module_name import function_name 导入特定函数 from module_name import funct ...