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

哪些网站是响应式网站网站运营是做什么的

哪些网站是响应式网站,网站运营是做什么的,logo做ppt模板下载网站,看网站搜什么关键词一.基本介绍 在有序列表中,元素的相对位置取决于它们的基本特征。它们通常以升序或者降序排列,并且我们假设元素之间能进行有意义的比较。有序列表和无序列表(链表)的许多操作都是相同的。 二.代码实现 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/a/516646.html

相关文章:

  • TDengine 配置参数作用范围对比
  • DDPM(Diffusion)个人总结
  • 解决了“错误的问题”:对AI编程热潮的深度反思
  • 【回眸】嵌入式软件面试题背诵版
  • FreeRTOS主要寄存器说明及面试题
  • 怎么写公司网站的文案做360手机网站
  • 涿州网站制作wordpress选中改变字体颜色
  • 企业如何进行海外营销?
  • 【sqlite】WAL初探
  • 制作网站的顺序是海南网上报名系统
  • 做网站都需要哪些知识珠海市住房和城乡建设局网站
  • MySQL分组查询GROUP BY
  • 数组——双指针:75.颜色分类
  • LLD文档核心:从模块设计到落地开发
  • 雄安做网站深圳出台科技支持政策
  • 网站域名能更该吗怎样用模板建网站
  • proc文件系统入门到精通教程
  • 点积、内积与哈达玛积详解
  • 杭州模板建站2022注册公司取名
  • 政务网站建设论文西地那非片吃了多久会硬起来
  • 金融杠杆全解析:从铁矿期货保证金计算到期权盈亏分析
  • 【工具变量】绿色金融改革创新试验区DID数据集(2000-2024年)
  • Prometheus:从概述到部署
  • 32.768khz音叉式圆柱型贴片晶振CMR200T
  • ROS2创建Python与C++功能包指南以及什么是节点(ros2第一章)
  • wordpress可以建网站吗电子商务网站建设 教案
  • vr中xr射线长度调整
  • 怎样做微信挂机平台网站建设公司的网站首页
  • 【Go】P11 掌握 Go 语言函数(二):进阶玩转高阶函数、闭包与 Defer/Panic/Recover
  • 无奈!我用go写了个MySQL服务