6-Python 数据结构初识

作者: LuCh1Monster | 来源:发表于2016-03-20 00:47 被阅读390次

    课程概要:
      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()
    

    相关文章

      网友评论

      • 648be709528c:class Stack():
        def __init__(st, size):
        st.stack=[]
        st.size=size
        st.top=-1
        参数里的st是什么意思?还有出栈少一个pop()吧
        LuCh1Monster:@积极健康向上的少年 st 指代的其实就是类函数的self

      本文标题:6-Python 数据结构初识

      本文链接:https://www.haomeiwen.com/subject/wneclttx.html