当前位置: 首页 > news >正文

网站建设的开票编码上海网站seo招聘

网站建设的开票编码,上海网站seo招聘,提供商城网站建设,独立站建站服务一、链表 1.1目的 解决顺序表存储数据有上限,并且插入和删除操作效率低的问题 1.2概念 链表:链式存储的线性表,使用随机物理内存存储逻辑上连续的数据 链表的组成:由一个个结点组成 结点:由数据域和链接域组成&a…

一、链表

1.1目的

解决顺序表存储数据有上限,并且插入和删除操作效率低的问题

1.2概念

链表:链式存储的线性表,使用随机物理内存存储逻辑上连续的数据

链表的组成:由一个个结点组成

结点:由数据域和链接域组成,是链表的基本单位

数据域:存储数据元素的区域

链接域:记录下一个结点所在位置的区域

头结点:虚设的一个结点,连接域专门记录链表第一个结点的位置,数据域专门记录链表的长度

1.3链表的种类

单向链表、双向链表、循环链表

二、单向链表

2.1单向链表的概念

只能通过头结点或链表的头,单向的访问后继结点的链表叫单向链表

2.2结点和链表类的格式

1】包含存储数据元素的数据域

2】有一个存储下一个结点的位置域

#封装普通节点的类
class Node:#构造函数,定义结点的属性def __init__(self,data):self.data=data#普通结点的数据域self.next=None#普通结点的连接域,刚构造的结点该位置域为空
#封装链表的类(封装头节点)
class Link_list():def __init__(self,node=None):self.size=0#头结点的数据域为0 链表的长度为0self.head=node#头结点的连接域指向None

2.3单向列表的相关操作(成员函数的封装)

1】单向链表的创建

2】判空

#判空def is_empty(self):return self.head#   return self.size==0  或者判断长度是否为零

3】头插

函数功能:将一个结点以头插的方式插入到头结点的后面

思路:

参数:self链表,要插入的数据

注意事项:需要申请结点封装数据

                  插入成功链表长度自增

#头插def add_head(self,value):#创建一个新的结点node=Node(value)node.next=self.headself.head=nodeself.size+=1

4】尾插

函数功能:将新的节点增加到链表的尾部。思路:(如上图)

函数返回值:无

函数名:符合命名规则

参数列表:self 链表,要插入的数据

注意事项:插入成功,链表自增

#尾插def add_tail(self, value):#创建一个结点nodenode = Node(value)#找最后一个结点# q = self.head# i=1# while i<self.size:#     q=q.next#     i+=1# q.next=node# self.size+=1#第二种方法q = self.headwhile q.next:q = q.nextq.next = nodeself.size += 1#第三种# while True:#     q=q.next#     if not q.next:#         q.next = node#         self.size+=1#         break

5】任意位置插

函数功能:在指定的位置插入一个节点 思路:如上图

函数返回值:无

函数名:符合命名规则

参数列表:self链表、要插入的位置、要插入的数据

注意事项:1、判断要插入的位置是否合理

2、成功插入 ;链表长度自增

3、如果是第一个位置,做头插

#任意位置插def add_any(self, id, value):node = Node(value)if id == 1:self.add_head(value)elif id == self.size+1:self.add_tail(value)elif id>self.size+1:print('插入失败')returnelse:q = self.headi = 1while i < id - 1:q = q.nexti += 1node.next = q.nextq.next = nodeself.size += 1

6】头删

#头删def del_head(self):self.head = self.head.nextself.size -= 1

7】尾删

#尾删def del_tail(self):if self.size==1:self.head=Noneelse:q = self.headfor i in range(self.size - 2):q = q.nextq.next = Noneself.size -= 1

8】任意位置删

#任意位置删def del_any(self,id):if id==1:self.del_head()else:q = self.headfor i in range(id - 2):q = q.nextq.next = q.next.nextself.size -= 1

9】遍历

函数功能:从头到尾打印出链表中每个节点的数据域的数据

函数返回值:无

函数名:符合命名规则

参数列表:self 链表

注意事项:判空

#遍历def show(self):#判空if self.is_empty():print('遍历失败')returnelse:q = self.headwhile q :print(q.data,end=' ')q = q.nextprint()

http://www.hrbkazy.com/news/42470.html

相关文章:

  • 上海做网站google官网注册账号入口
  • 建设银行网站打开自动关闭上海何鹏seo
  • 亿方云企业网盘嘉兴seo外包公司
  • 重庆网站制作外包公司站长收录平台
  • 网站公安备案 北京seo是什么软件
  • 山东网站建设企业企业网站运营推广
  • 网站结构是什么 怎么做b2b和b2c是什么意思
  • 源代码怎么做网站产品软文范例
  • 计算机网站建设文献综述宁波网站推广制作
  • 豫建市2021 42号seo沈阳
  • 先注册域名后建设网站可以吗白帽seo
  • 做日本假货的在什么网站卖好seo网站推广工作内容
  • 南通技术网站seo优化一般包括哪些
  • cloud web 网站建设模板建站和开发网站区别
  • wordpress网站定制网络推广外包加手机蛙软件
  • 武安做网站网络营销推广实战宝典
  • 网站个人微信收款方案网站换了域名怎么查
  • 网络平台推广运营骗局seo快速排名上首页
  • 如何优化网站三十个知识点带你学党章
  • 网站空间和云主机灰色行业seo
  • html代码自动生成器网站seo顾问
  • 网站变更备案aso优化是什么意思
  • 做弹幕网站广州抖音推广
  • 涪陵网站建设国外免费网站建设
  • 都市网网站seo方案
  • 建设网站英语如何做好网站推广优化
  • 社区网站怎么做北京效果好的网站推广
  • 无锡专业网站字节跳动广告代理商加盟
  • wordpress全站ajax西安seo优化推广
  • 石家庄城市建设投资中心网站全网推广推荐