Python 数据结构与算法 —— 初识算法

算法是什么?

举个简单例子:

我们要做一份蛋炒饭:

  1. 拿钱包,出门,去菜市场购买鸡蛋和大米以及油和盐——购买蛋炒饭的材料
  2. 回家将大米淘洗干净放进电饭煲——煮熟大米
  3. 将锅放在电磁炉上加热——往锅里倒适量油
  4. 将鸡蛋打开放入油锅——翻炒鸡蛋至七分熟
  5. 将适量煮熟的米饭倒入锅中,加盐——翻炒两分钟

以上就是制作一份简单蛋炒饭的步骤

如果把这些交给机器来做,也是如此,并且步骤将更加细分和严谨

简单来讲,这就是算法

那么算法到底是什么呢?

先来看一道简单的高中数学题:

现有a,b,c三个自然数,要求满足以下条件:

1.a+b+c = 1000

2.a^2 + b^2 = c^2 (^代表平方)

分析:

首先排除数学公式,我们使用机器思维来计算这道题,能想到的办法也很简单,即一个一个数尝试
,直到试出准确答案为止,此种方法我们称之为 枚举法

上面数学题使用Python来实现:
import time


start_time = time.time()
for a in range(0, 1001):
    for b in range(0, 1001):
        for c in range(0, 1001):
            if a+b+c == 1000 and a**2 + b**2 == c**2:
                print("a, b, c: %d, %d,%d" % (a, b, c))

end_time = time.time()
print("time:%d" % (end_time - start_time))
print("finished!")

代码执行结果:

C:\python3\setup\python.exe C:/Users/limia/Desktop/DataS/01_枚举组合.py
a, b, c: 0, 500,500
a, b, c: 200, 375,425
a, b, c: 375, 200,425
a, b, c: 500, 0,500
time:121
finished!

Process finished with exit code 0

注释: 在上面的代码中:计算这道数学题的同时,还引入了time模块来计算这段代码的运行时间,以方便之后对比算法效率

通过分析这道题,我们可以得知,a+b+c=1000,在有了a和b的值之后,c的值自然就可以计算为:1000-a-b,分析至此,则代码可以改进为以下:

import time


start_time = time.time()
for a in range(0, 1001):
    for b in range(0, 1001):
        c = 1000 - a -b
        if a**2 + b**2 == c**2:
            print("a, b, c: %d, %d,%d" % (a, b, c))

end_time = time.time()
print("time:%d" % (end_time - start_time))
print("finished!")

代码执行结果:

C:\python3\setup\python.exe C:/Users/limia/Desktop/DataS/01_枚举组合.py
a, b, c: 0, 500,500
a, b, c: 200, 375,425
a, b, c: 375, 200,425
a, b, c: 500, 0,500
time:1
finished!

Process finished with exit code 0

通过对比,可以一目了然的发现,改进后的代码执行效率(1s)明显高于第一种代码执行效率(121s)

算法的概念:

算法是计算机处理信息的本质

算法是独立存在的一种解决问题的方法和思想

计算机程序本质上是一个算法来告诉计算机确切的步骤来执行一个指定的任务

单纯以时间衡量算法效率是否是科学的、客观的?

答案:不客观

假设在一台古老的计算机上运行上面的两个程序,则其所消耗的时间都将是极长的,因此单纯以时间计算算法的效率是不科学的。

在衡量算法的效率时,应当脱离计算机来估算

因此引入时间复杂度来衡量算法的效率

每台计算机执行的总时间不同,但是执行基本运算数量大体相同

上面的两个程序,以时间复杂度来表示算法效率:
T = 1000 * 1000 * 1000 * 2

==》 当计算的不是a+b+c=1000,而是a+b+c=2000时,以时间复杂度表示则

T = 2000 * 2000 * 2000 * 2

==》 当计算的不是1000或者2000,而是n呢?

T(n) = n * n * n * 2

简化:

T(n) = n^3 * 2

则此时 **T(n) = n^3 * 2 ** 即为这个程序算法的时间复杂度函数

通过函数 T(n) = n^3 * 2 ,可做出曲线图

系数对曲线形状改变不大,只是陡峭不同,因此 T(n) = n^3 * 2 可以简化为T(n) = n^3

T(n) = n^3 则可以叫做 T(n) = n^3 * 2 的渐进函数

大O表示法

上述 **T(n) = n^3 ** 就是 ** T(n) = n^3 * 2 ** 的大O 表示法

总结: 大O表示法只留下表示特征的部分

常见时间复杂度之间的关系

O(1) < O(logn) < O(n) < O(nlogn) < O(n^2) < O(n^3) < O(2^n) < O(n!) < O(n^n)

个人博客地址:www.limiao.tech
微信公众号:TechBoard
慕课网:techLee


如果觉得文章对您有所帮助,那就伸出小手 ==>> 点击下方 [ like ] 吧

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 162,306评论 4 370
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 68,657评论 2 307
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 111,928评论 0 254
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 44,688评论 0 220
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 53,105评论 3 295
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 41,024评论 1 225
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 32,159评论 2 318
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,937评论 0 212
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,689评论 1 250
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,851评论 2 254
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,325评论 1 265
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,651评论 3 263
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,364评论 3 244
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,192评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,985评论 0 201
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 36,154评论 2 285
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,955评论 2 279

推荐阅读更多精彩内容

  • 专业考题类型管理运行工作负责人一般作业考题内容选项A选项B选项C选项D选项E选项F正确答案 变电单选GYSZ本规程...
    小白兔去钓鱼阅读 8,898评论 0 13
  • 在C语言中,五种基本数据类型存储空间长度的排列顺序是: A)char B)char=int<=float C)ch...
    夏天再来阅读 3,106评论 0 2
  • 《床诗》 我是一张被摆放的床 于溪水湖边 于林边草地 教堂的台阶下 石桥的身躯上 诗和远方的云中 生活在别处的路边...
    穿裤孑的云阅读 923评论 2 10
  • 《古风·仙女山》 温志龄 武陵仙脉一名山,伊甸圣迹落凡间。 奔腾乌江濯...
    碧野牧歌阅读 397评论 0 2
  • 从泊雯上幼儿园开始,就一直在画画,她喜欢画,我也是就让她玩玩而已。学会色彩搭配,有鉴赏力也不错。慢慢来吧,静待花...
    悦辰4134阅读 183评论 0 0