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

郑州科大医院seo查询 站长工具

郑州科大医院,seo查询 站长工具,小程序制作软件,家电企业网站模板一.基本介绍 在有序列表中,元素的相对位置取决于它们的基本特征。它们通常以升序或者降序排列,并且我们假设元素之间能进行有意义的比较。有序列表和无序列表(链表)的许多操作都是相同的。 二.代码实现 class OrderedList:"""有序列表类…

一.基本介绍

      在有序列表中,元素的相对位置取决于它们的基本特征。它们通常以升序或者降序排列,并且我们假设元素之间能进行有意义的比较。有序列表和无序列表(链表)的许多操作都是相同的。

二.代码实现

class OrderedList:"""有序列表类"""def __init__(self):"""初始化有序列表的头部,使其为None"""self.head = Nonedef is_empty(self):"""判断有序列表的头部是否为空"""return self.head == Nonedef size(self):"""返回有序列表中节点的数量"""current = self.headcount = 0while current != None:count += 1current = current.next_nodereturn countdef remove(self,data):"""删除有序列表中的指定节点"""current = self.headprevious = Nonewhile current != None:if current.data == data:if previous == None:self.head = current.next_nodeelse:previous.next_node = current.next_nodereturnprevious = currentcurrent = current.next_nodeprint(f"{data} is not in the list")def add(self,data):"""向有序列表中添加节点"""temp = Node(data)current = self.headprevious = Noneif current == None:temp.next_node = self.headself.head = tempwhile current != None:if current.data > data:temp.next_node = currentprevious.next_node = tempbreak    previous = currentcurrent = current.next_node             def search(self,data):"""查找指定的元素是否在有序列表中"""current = self.headwhile current != None:if current.data == data:return Trueelif current.data > data:return Falsecurrent = current.next_nodereturn False

但是,上面这段代码有很多地方是需要优化的

  1. 推荐使用is或者is not,而不是==或!= 

        这是因为is用于比较两个对象的身份(即它们是否是同一个对象)。在Python中,None是一个特殊的单例对象,这意味着在整个程序的生命周期中,None只有一个实例。使用is检查None是检查变量是否指向唯一的那个None对象

     2.==操作符用于判断两个对象的值是否相等,对于自定义对象,==操作符的行为可以通过定义__eq__方法来改变

     3.使用is None表明你正在检查变量是否为None,而不是检查变量的值是否等于None,语义更明确,代码更易读和易于维护

     4.is操作符直接比较对象的身份,是一个非常快速的操作,==操作符可能会通过__eq__方法重写使得本身不是None的对象在==None时返回True

     5.在add方法中temp.next_node = self.head是没有多余的,因为此时有序列表是空列表,头部没有元素,self.head本身就是None,直接设置self.head=temp就足够了

优化后的代码

class OrderedList:"""有序列表类"""def __init__(self):"""构造函数,初始化有序列表的表头"""self.head = Nonedef is_empty(self):"""检查有序列表是否为空"""return self.head is Nonedef add(self,data):"""向有序列表中添加节点"""temp = Node(data)current = self.headprevious = Noneif current is None: # 如果有序列表头部为空self.head = tempwhile current is not None: # 如果头部且当前节点都不为空if current.data > data: # 如果当前节点的数据大于要插入的数据,说明要插入的数据应该放在当前节点的前面if previous is None: # 如果目标节点比有序列表头部节点小,此时previous为Noneself.head = tempelse: # 目标节点比有序列表头部节点大,previous一定不为Noneprevious.next_node = temptemp.next_node = currentreturnprevious = currentcurrent = current.next_nodedef search(self,data):"""检查指定的节点是否在有序列表中"""current = self.headwhile current is not None:if current.data == data:return Truecurrent = current.next_nodereturn Falsedef remove(self,data):"""从有序列表中删除指定的节点"""current = self.headprevious = Nonewhile current is not None:if current.data == data:if previous == None:self.head = current.next_nodeelse:previous.next_node = current.next_nodereturnprevious = currentcurrent = current.next_noderaise ValueError(f"{data} is not in the list")def size(self):"""返回有序列表中的节点个数"""current = self.headcount = 0while current is not None:count += 1current = current.next_nodereturn countdef display(self):"""显示有序列表的结构"""current = self.headwhile current is not None:print(current.data,end=' -> ')current = current.next_nodeprint(None)

依旧有问题,add方法中没有处理要添加的元素是有序列表中的最后一个元素的这种情况

add方法中逻辑混乱

应先判断要添加的位置,在执行添加操作

class OrderdeList:def __init__(self):self.head = Nonedef is_empty(self):return self.head is Nonedef add(self,data):temp = Node(data)current = self.headprevious = Nonewhile current is not None and current.data < data:previous = currentcurrent = current.next_nodeif previous is None:temp.next_node = self.headself.head = tempelse:previous.next_node = temptemp.next_node = currentdef search(self,data):current = self.headwhile current is not None:if current.data == data:return Truecurrent = current.next_nodereturn Falsedef remove(self,data):current = self.headprevious = Nonewhile current is not None:if current.data == data:if previous is None:self.head = current.next_nodeelse:previous.next_node = current.next_nodereturnprevious = currentcurrent = current.next_noderaise ValueError(f"{data} is not in the list")def size(self):current = self.headcount = 0while current is not None:count += 1current = current.next_nodereturn countdef display(self):current = self.headwhile current is not None:print(current.data,end=' -> ')current = current.next_nodeprint(None)

http://www.dtcms.com/wzjs/225169.html

相关文章:

  • 手机网站如何做才能兼容性各种手机公关服务
  • 怎样浏览被国内封禁的网站全网热搜榜第一名
  • 政府网站集群建设方案哪个搜索引擎最好用
  • 江津区住房和城乡建设委员会网站爱站网关键词挖掘工具站长工具
  • 游戏网站怎么赚钱宣传推广方案
  • 本地建站软件班级优化大师客服电话
  • 门户网站含义阿里云建站费用
  • 制作网站价格不一品牌营销策划是干嘛的
  • 上传网站空间的建站程序怎么删除徐州关键词优化排名
  • 做企业网站流程技能培训学校
  • 制作视频教程百度app优化
  • 论职能网站建设怎样制作一个网站
  • 务川网站建设公司品牌营销策划
  • 网站做端口映射淄博搜索引擎优化
  • 如皋网站建设招标中国最新军事新闻最新消息
  • 靖江做网站b2b免费发布网站大全
  • 沧州做家装的公司网站手机网站怎么优化关键词
  • 注册网站费用明细国内免费域名
  • 金湖建设局网站seo待遇
  • 做网站需要用什么开发软件文案发布平台
  • 做外贸如何选择网站南京seo排名优化
  • 网站域名注册商标kol营销模式
  • 最超值的手机网站建设新媒体平台
  • 外贸批发网站建设郑州seo顾问外包公司
  • 运城市做网站价格百度大数据查询
  • 网站百度贴吧2023第二波疫情已经到来了
  • 影视类网站建设如何做线上销售和推广
  • 免费注册自己的网站站长工具传媒
  • 刷QQ砖的网站咋做百度客户端在哪里打开
  • 保山公司做网站十大室内设计网站