python数据的存储结构知识点_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进行操作。

二、栈的图示

三、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中队列的实现

一、什么事队列

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

二、队列的图示

三、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()

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值