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

江苏广兴建设集团网站wordpress 前台英文

江苏广兴建设集团网站,wordpress 前台英文,shopex网站经常出错,网站建设财务上怎么处理目录 1#xff0c;数据结构中的一些概念2#xff0c;栈#xff08;stack#xff09;3#xff0c;队列4#xff0c;链表5#xff0c;数组 1#xff0c;数据结构中的一些概念 1、数据结构是什么 1、简单来说#xff0c;数据结果就是设计数据以何种方式存储在计算机中 …目录 1数据结构中的一些概念2栈stack3队列4链表5数组 1数据结构中的一些概念 1、数据结构是什么 1、简单来说数据结果就是设计数据以何种方式存储在计算机中 2、比如列表集合与字典等都是一种数据结构 3、程序 数据结构 算法 2、数据结构与数据类型 1数据类型 说明数据类型是一个值的集合和定义在此集合上一组操作通常是增删改查或者操作读写的方法的总称 数据类型int、str、boolean、byte 2数据结构 说明数据以什么方式构成如何进行存储数据结构是数据类型中的一种结构类型 数据结构数组、栈、队列、链表、树、图、堆、散列表等 python数据结构列表、集合、字典、元祖 3、数据结构与数据类型比较 数据类型的分类为原子类型 和 结构类型原子类型 一种值的集合 定义在值集合上的一组操作。比如python中的intfloat字符串结构类型 一种数据结构 定义在这种数据结构上的一组操作。比如python中的列表字典元组 原子类型 结构类型 数据类型 注数据类型是一个值的集合和定义在此集合上一组操作通常是增删改查或者操作读写的方法的总称 2栈stack 1、栈的定义 栈是一种数据集合可以理解为只能在一端进行插入或删除操作的列表 2、栈的特点 后进先出last-in, first-out 3、栈的概念 栈顶栈底 4、栈的基本操作 进栈压栈push 出栈pop 取栈顶gettop python实现栈功能 #! /usr/bin/env python # -*- coding: utf-8 -*- class Stack(object):def __init__(self):self.stack [] # 初始化一个栈def push(self,item): # 入栈self.stack.append(item)def gettop(self): # 获取栈顶元素return self.stack[-1]def pop(self): # 出栈return self.stack.pop()if __name__ __main__:s Stack()s.push(1)s.push(2)print(s.stack)5、栈的使用匹配括号是否成对出现 def check_kuohao(s):stack []for char in s:if char in [(,[,{]:stack.append(char)elif char ):if len(stack)0 and stack[-1] (:stack.pop()else:return Falseelif char ]:if len(stack) 0 and stack[-1] [:stack.pop()else:return Falseelif char }:if len(stack) 0 and stack[-1] {:stack.pop()else:return Falseif len(stack) 0:return Trueelse:return False print(check_kuohao((){}{}[])) #True3队列 1、队列定义 1、队列是一个数据集合仅允许在列表的一端进行插入另一端进行删除 2、插入的一端称为队尾rear插入动作叫进队或入队 3、进行删除的一端称为对头front删除动作称为出队 4、队列性质先进先出First-in, First-out 5、双向队列队列的两端都允许进行进队和出队操作 2、对列使用方法 1、导入 from collectios import deque 2、创建队列queue deque(li) 3、进队 append 4、出队 popleft 5、双向队列队首进队appendleft 6、双向队列队尾出队pop python操作队列queue from queue import Queue #1. 基本FIFO队列 先进先出 FIFO即First in First Out,先进先出 #2. maxsize设置队列中数据上限小于或等于0则不限制容器中大于这个数则阻塞直到队列中的数据被消掉 q Queue(maxsize0)#3. 写入队列数据 q.put(0) q.put(1) q.put(2)#4. 输出当前队列所有数据 print(q.queue)#5. 删除队列数据并返回该数据 q.get()#6. 输也所有队列数据 print(q.queue)3、双向对列原理图 1、 环形对列当对位指针front Maxsize 1 时再进一个位置就自动到0 2、 实现方法求余数运算 3、 队首指针前进1 front (front 1)%MaxSize 4、 队尾指针前进1rear (rear1)%MaxSize 5、 队空条件rear front 6、 队满条件rear1%MaxSize front 4、队列应用场景 队列主要的功能是在多个进程间共享数据实现业务解耦提高效率生产者线程只需要把任务放入队列中消费者线程只需要到队列中取数据进行处理 5、队列与列表区别 列表中数据虽然是排列的但数据被取走后还会保留而队列中这个容器的数据被取后将不会保留 4链表 1、单链表 注链表中每个元素都是一个对象每个对象称为一个节点包含有数据域key和指向下一节点的指针next通过各个节点间的相互连接最终串联成一个链表 python模拟链表数据类型 class Node(object):def __init__(self, item,nextNone):self.item itemself.next next l Node(1,Node(2,Node(3,Node(4)))) print(l.item) print(l.next.item)单链表增删改查 #! /usr/bin/env python # -*- coding: utf-8 -*- class Node(object):def __init__(self, item):self.item itemself.next Noneclass DLinkList(object):def __init__(self):self._head Nonedef is_empty(self):return self._head Nonedef append(self, item):尾部追加元素node Node(item)if self.is_empty():self._head nodeelse:cur self._headwhile cur.next ! None:cur cur.nextcur.next nodedef add(self, item):头部插入元素node Node(item)if self.is_empty():self._head node # 如果是空链表将_head指向nodeelse:node.next self._head # 将node的next指向_head的头节点self._head node # 将_head 指向nodedef travel(self):cur self._headwhile cur ! None:print (cur.item),cur cur.nextprint ()def remove(self, item):删除元素if self.is_empty():returnelse:cur self._headif cur.item item:# 如果首节点的元素即是要删除的元素if cur.next None: # 如果链表只有这一个节点self._head Noneelse: # 将_head指向第二个节点self._head cur.nextreturnwhile cur ! None:if cur.next.item item:cur.next cur.next.nextbreakcur cur.nextdef insert(self, pos, item):在指定位置添加节点if pos 0:self.add(item)elif pos (self.length() - 1):self.append(item)else:node Node(item)cur self._headcount 0# 移动到指定位置的前一个位置while count (pos - 1):count 1cur_next cur.next# 将node的next指向cur的下一个节点cur.next nodenode.next cur_nextdef length(self):返回链表的长度cur self._headcount 0while cur ! None:count 1cur cur.nextreturn countif __name__ __main__:ll DLinkList()# 1、将链表后面追加三个元素1,2,3ll.append(1)ll.append(2)ll.append(3)ll.travel() # 1 2 3# 2、将链表头部插入一个元素0ll.add(0)ll.travel() # 1 2 3 0 1 2 3# 3、删除链表中的元素3ll.remove(3)ll.travel() # 0 1 2 3 0 1 2# 4、在链表的第2号位置插入元素8ll.insert(2,8)ll.travel() # 0 1 2 0 8 1 2链表反转 class Node(object):def __init__(self, val):self.val valself.next Nonedef list_reverse(head):if head None:return NoneL, R, cur None, None, head # 左指针、有指针、游标while cur.next ! None:L R # 左侧指针指向以前右侧指针位置R cur # 右侧指针前进一位指向当前游标位置cur cur.next # 游标每次向前进一位R.next L # 右侧指针指向左侧实现反转cur.next R # 当跳出 while 循环时 cur(原链表最后一个元素) R(原链表倒数第二个元素)return curif __name__ __main__:原始链表1 - 2 - 3 - 4反转链表4 - 3 - 2 - 1l1 Node(1)l1.next Node(2)l1.next.next Node(3)l1.next.next.next Node(4)l list_reverse(l1)print l.val # 4 反转后链表第一个值4print l.next.val # 3 第二个值3链表排序归并排序算法实现 class ListNode(object):def __init__(self, val, nextNone):self.val valself.next next# 归并法: 对链表排序 class Solution:def sortList(self, head):if head is None or head.next is None:return headpre headslow head # 使用快慢指针来确定中点fast headwhile fast and fast.next:pre slowslow slow.nextfast fast.next.nextleft headright pre.nextpre.next None # 从中间打断链表left self.sortList(left)right self.sortList(right)return self.merge(left, right)def merge(self, left, right):pre ListNode(-1)first prewhile left and right:if left.val right.val:pre.next leftpre leftleft left.nextelse:pre.next rightpre rightright right.nextif left:pre.next leftelse:pre.next rightreturn first.nextnode1 ListNode(4) node2 ListNode(3) node3 ListNode(2) node4 ListNode(1)node1.next node2 node2.next node3 node3.next node4s Solution() result s.sortList(node1)while (result ! None):print result.val, # 1 2 3 4result result.next对python列表排序归并排序 对比 def mergesort(seq):if len(seq) 1:return seqmid int(len(seq) / 2)left mergesort(seq[:mid])right mergesort(seq[mid:])return merge(left, right)def merge(left, right):result []i, j 0, 0while i len(left) and j len(right):if left[i] right[j]:result.append(left[i])i 1else:result.append(right[j])j 1result left[i:]result right[j:]return resultif __name__ __main__:seq [10,4,6,3,8,2,5,7]print mergesort(seq) # [2, 3, 4, 5, 6, 7, 8, 10]2、双链表 注双链表中每个节点有两个指针一个指针指向后面节点、一个指向前面节点 双链表增删改查 class Node(object):双向链表节点def __init__(self, item):self.item itemself.next Noneself.prev Noneclass DLinkList(object):双向链表def __init__(self):self._head Nonedef is_empty(self):判断链表是否为空return self._head Nonedef length(self):返回链表的长度cur self._headcount 0while cur ! None:count 1cur cur.nextreturn countdef travel(self):遍历链表cur self._headwhile cur ! None:print cur.item,cur cur.nextprint def add(self, item):头部插入元素node Node(item)if self.is_empty():# 如果是空链表将_head指向nodeself._head nodeelse:# 将node的next指向_head的头节点node.next self._head# 将_head的头节点的prev指向nodeself._head.prev node# 将_head 指向nodeself._head nodedef append(self, item):尾部插入元素node Node(item)if self.is_empty():# 如果是空链表将_head指向nodeself._head nodeelse:# 移动到链表尾部cur self._headwhile cur.next ! None:cur cur.next# 将尾节点cur的next指向nodecur.next node# 将node的prev指向curnode.prev curdef search(self, item):查找元素是否存在cur self._headwhile cur ! None:if cur.item item:return Truecur cur.nextreturn Falsedef insert(self, pos, item):在指定位置添加节点if pos 0:self.add(item)elif pos (self.length() - 1):self.append(item)else:node Node(item)cur self._headcount 0# 移动到指定位置的前一个位置while count (pos - 1):count 1cur cur.next# 将node的prev指向curnode.prev cur# 将node的next指向cur的下一个节点node.next cur.next# 将cur的下一个节点的prev指向nodecur.next.prev node# 将cur的next指向nodecur.next nodedef remove(self, item):删除元素if self.is_empty():returnelse:cur self._headif cur.item item:# 如果首节点的元素即是要删除的元素if cur.next None:# 如果链表只有这一个节点self._head Noneelse:# 将第二个节点的prev设置为Nonecur.next.prev None# 将_head指向第二个节点self._head cur.nextreturnwhile cur ! None:if cur.item item:# 将cur的前一个节点的next指向cur的后一个节点cur.prev.next cur.next# 将cur的后一个节点的prev指向cur的前一个节点cur.next.prev cur.prevbreakcur cur.nextif __name__ __main__:ll DLinkList()ll.add(1)ll.add(2)# ll.append(3)# ll.insert(2, 4)# ll.insert(4, 5)# ll.insert(0, 6)# print length:,ll.length()# ll.travel()# print ll.search(3)# print ll.search(4)# ll.remove(1)print length:,ll.length()ll.travel()双链表追加和遍历 class Node(object):def __init__(self, item):self.item itemself.next Noneself.prev Noneclass DLinkList(object):def __init__(self):self._head Nonedef is_empty(self):return self._head Nonedef append(self, item):node Node(item)if self.is_empty():self._head nodeelse:cur self._headwhile cur.next ! None:cur cur.nextcur.next nodenode.prev curdef travel(self):cur self._headwhile cur ! None:print cur.item,cur cur.nextif __name__ __main__:ll DLinkList()ll.append(1)ll.append(2)ll.append(3)# print ll._head.item # 打印第一个元素1# print ll._head.next.item # 打印第二个元素2# print ll._head.next.next.item # 打印第三个元素3ll.travel() # 1 2 35数组 1、数组定义 所谓数组就是相同数据类型的元素按一定顺序排列的集合在Java等其他语言中并不是所有的数据都能存储到数组中只有相同类型的数据才可以一起存储到数组中。因为数组在存储数据时是按顺序存储的存储数据的内存也是连续的所以他的特点就是寻址读取数据比较容易插入和删除比较困难。 2、python中list与数组比较 python中的list是python的内置数据类型list中的数据类不必相同的而array的中的类型必须全部相同。在list中的数据类型保存的是数据的存放的地址简单的说就是指针并非数据否则这样保存一个list就太麻烦了例如list1[1,2,3,‘a’]需要4个指针和四个数据增加了存储和消耗cpu。 python中字典对象实现原理详解
http://www.yayakq.cn/news/5211/

相关文章:

  • 怎么看网站是否被百度惩罚做的网站图片显示一半
  • 苏州网站设计公司兴田德润在哪里呢学校网站建设钉钉
  • 建站模板网站设计优化 导航网站
  • 友山建站优化网站建设项目化教程
  • 网站企业快速备案流程freenom怎么做网站
  • 网站开发必备技能商业网站建设设计
  • 电力行业做的好的招投标网站十大平面设计公司
  • 电商网站建设参考文献如何做一份网站的数据分析
  • 做一个静态网站导航要多少钱网站报价
  • 网站建设服务专业建站公司什么公司做企业网站
  • jquery网站开发实例高端定制外贸网站
  • 企业网站选wordpress和织梦seo技术代理
  • 做网站主流技术设计参考图网站
  • 怎么做网站代理商无锡企业网站排名优化
  • 网站专题二级页怎么做广西南宁生活网
  • 海淀区企业网站建设thinkphp做网站有什么好处
  • 一手项目对接app平台seo如何选择网站标题
  • 冠辰网站建设网站页面好了怎么做后端
  • 公司网站开发模板建设集团摩托车
  • 深圳企业网站模板重庆市哪个区最繁华
  • wordpress站点字体修改西部数码网站管理助手错误
  • 如何禁止某ip访问网站网站网站建设设计
  • 建设企业网站平台主要的目的是界面设计模式读后感
  • 怎么用php做网站后台程序企业网站 优秀
  • 手机网站设计教育类模板夏天做那些网站致富
  • 旅游网站的设计方案怎么做网站设置密码
  • 徐州做网站xlec网站开发一级分销
  • 电信ip做的网站移动不能访问公司官网开发
  • 做暧暖网站江阳建设集团网站
  • 专业设计网站公司网站建设捌金手指花总四