6-Python 数据结构初识

课程概要:
  1、Python 数据结构概述
  2、Python 常见数据结构——栈
  3、Python 常见数据结构——队列

1、Python 数据结构概述

知识点:
  ◆ 什么是数据结构?
  ◆ 数据结构实例
  ◆ 数据结构与算法的关系

一、什么是数据结构?

我们知道,一个程序里面必然会有数据存在,同样的一个或几个数据要组织起来,可以有不同的组织方式,也就是不同的存储方式。不同的组织方式就是不同的结构,我们把这些数据组织在一起的结构称之为数据的结构,也叫做数据结构。比如,有一字符串是”abc”,我们将其重新组织一下,比如通过list() 函数将”abc”变成[“a”, “b”, “c”],那么这个时候数据就发生了重组,重组之后数据的结构就变了,变成了了[“a”, “b”, “c”],我们把这种形式的数据的结构叫做列表,也就是说列表是数据结构中一种类型之一。数据结构除了列表之外,还有元组、字典、队列、栈、树等等。Python 中数据的组织方式叫做Python
的数据结构。

二、数据结构实例

Python 中的数据结构有非常多种类型。其中,Python 中系统自己定义好的,不需要我们自己去定义的数据结构叫做Python 的内置数据结构,比如列表、元组等,而有些数据组织方式,Python 系统里面没有直接定义,需要我们自己去定义实现这些数据的组织方式,这些数据组织方式称之为Python 的扩展数据结构,比如栈,队列等。

Python 内置的数据结构有元组、列表、字典等

【实例】现在有三个物品,分别是"apple", "orange","pear" 需要将这三个物品存储起来

["apple", "orange", "pear"]     #       元素可更改

("apple", "orange", "pear")      #       元素不可更改
 
{"Sam":"apple", "Jac"
"orange", "Mating":"pear"}

三、数据结构与算法的关系

我们会发现Python 的数据结构经常与算法合在一起讲,但是我们是否想过,为什么要将数据结构与算法放在一起讲呢?刚才我们也说过了,数据结构就是数据的组织方式,就是数据存储的方式,也就是说,数据结构是静态的。算法是指运算方法,通俗的说,算法就是思维。我们编写的程序,是动态的,我们需要将数据进行计算,那么我们如何运算呢?运算方法有很多,不同的运算方法叫做不同的算法。比如1 +7 + 9 的计算方法。也就是说算法是动态的,是指运算的思维方法。当然我们的算法不是凭空出来的,它必须建立在数据的基础上,所以数据结构是算法的基础,但相同的数据结构运用不同的算法拥有不同的效率。


2、Python 常见数据结构-栈

知识点:

  • 什么是栈
  • 栈的图示
  • Python的栈的实现

一、什么是栈

首先,栈是一种数据结构。这种数据结构在Python中不是内置数据结构,属于扩展数据结构。这种数据结构具有这些特点:首先,栈相当于一端开口一端封闭的容器,数据A可以存储在栈里面,把数据A移动到栈里面这个过程叫做进栈,也叫压栈、入栈,数据A进入到栈里面之后,就到了栈顶,同时占了栈的一个位置。当再进入一个数据B的时候,也就是再将一个数据入栈的时候,这个时候,新的数据就占据了栈顶的位置,原来的数据就被新的数据压入到了栈顶的下一个位置里。栈只能对其栈顶的数据进行操作,可以将其出栈或删除等。等数据B出栈后,方可对A进行操作。

二、栈的图示

</br>

三、Python中栈的实现

【代码】

# -*- coding:utf8 -*-
# 栈的实现
# st 栈的主体       size 栈的容量

class Stack():
    def __init__(st, size):
        st.stack=[]
        st.size=size
        st.top=-1

    def push(st, content):
        if st.Full():
            print "Stack is Full"
        else:
            st.stack.append(content)
            st.top=st.top+1

    def out(st):
        if st.Empty():
            print "Stack is Empty"
        else:
            st.top=st.top-1
        
    def Full(st):
        if st.top==st.size:
            return True
        else:
            return False

   def Empty(st):
        if st.top==-1:
            return True
        else:
            return False

【输出】

>>> q=Stack(7)
>>> q.Empty()
True
>>> q.push("hello")
>>> q.Empty()
False
>>> q.out()

3、Python常见数据结构-队列

知识点:

  • 什么是队列
  • 队列的图示
  • Python中队列的实现

一、什么事队列

首先,队列也是一种数据结构。这种数据结构也是扩展的数据结构。这种数据结构具有这些特点:首先,队列相当于两端都开的容器,但是一端只能进行删除操作,不能进行插入操作,而另一端只能进行插入操作而不能进行删除操作,进行插入操作的这端叫做队尾,进行删除操作的这端叫做队首。所以队列中大家要记住这一点:数据是从队尾进队首出的。

二、队列的图示

</br>

三、Python中队列的实现

【代码】

# -*- coding:utf8 -*-
# 队列的实现
# qu 队列的主体       size 队列的容量

class Queue():
    def __init__(qu, size):
        qu.queue=[]
        qu.size=size
        qu.head=-1
        qu.tail=-1

    def Empty(qu):
        if qu.head==qu.tail:
            return True
        else:
            return False

    def Full(qu):
        if qu.tail-qu.head+1==qu.size:
            return True
        else:
            return False

    def enQueue(qu, content):
        if qu.Full():
            print "Queue is Full"
        else:
            qu.queue.append(content)
            qu.tail=qu.tail+1

    def outQueue(qu):
        if qu.Empty():
            print "Queue is Empty"
        else:
            qu.head=qu.head+1

【输出】

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

推荐阅读更多精彩内容