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

漯河网站推广公司济南专业做网站公司

漯河网站推广公司,济南专业做网站公司,lamp网站怎么建设,浙江省建设信息港查1.有效的括号 问题#xff1a; 给定一个只包括 (#xff0c;)#xff0c;{#xff0c;}#xff0c;[#xff0c;] 的字符串 s #xff0c;判断字符串是否有效。 有效字符串需满足#xff1a; 左括号必须用相同类型的右括号闭合。左括号必须以正确的顺序闭合。每个右…1.有效的括号 问题 给定一个只包括 (){}[] 的字符串 s 判断字符串是否有效。 有效字符串需满足 左括号必须用相同类型的右括号闭合。左括号必须以正确的顺序闭合。每个右括号都有一个对应的相同类型的左括号。 方法栈左入右出注意栈空和栈有余 # 栈左括号入栈右括号出栈注意栈空和栈有余的情况 def is_val(s):hash {(:), [:], {:}}# if not s:# return Truestack []index 0while index len(s):# 入栈情况左括号if s[index] in hash.keys():stack.append(s[index])# 出栈情况右括号elif s[index] in hash.values():# 空栈情况会报错if not stack:return False# 出栈 对比elif hash[stack.pop()] ! s[index]:return Falseindex 1# 栈剩余if stack:return Falsereturn True print(is_val(([]))) 2.最小栈 问题 设计一个支持 push pop top 操作并能在常数时间内检索到最小元素的栈。 实现 MinStack 类: MinStack() 初始化堆栈对象。void push(int val) 将元素val推入堆栈。void pop() 删除堆栈顶部的元素。int top() 获取堆栈顶部的元素。int getMin() 获取堆栈中的最小元素。 方法 # 注意最小值要用栈来保存否则更新不及时 class MinStack:def __init__(self, nums[]):self.nums nums# self.min float(inf) # 注意 这里需要用栈来保存最小值如果用值来保存元素出栈之后最小值可能更新不及时 self.min_stack []def push(self, val):self.nums.append(val)if not self.min_stack or self.min_stack[-1] val:self.min_stack.append(val)def pop(self):pop_val self.nums.pop()if pop_val self.min_stack[-1]: # 更新最小值self.min_stack.pop()return pop_valdef top(self):if self.nums:return self.nums[-1]return Nonedef getMin(self):if self.min_stack:return self.min_stack[-1]else:return Nonem_s MinStack() print(m_s.push(-2)) print(m_s.push(0)) print(m_s.push(-3)) print(m_s.getMin()) print(m_s.pop()) print(m_s.top()) print(m_s.getMin()) 注意这里最小值要用栈来保存如果用值保存最小值有元素弹出之后会导致更新不及时。 3.字符串解码 问题 给定一个经过编码的字符串返回它解码后的字符串。 编码规则为: k[encoded_string]表示其中方括号内部的 encoded_string 正好重复 k 次。注意 k 保证为正整数。 你可以认为输入字符串总是有效的输入字符串中没有额外的空格且输入的方括号总是符合格式要求的。 此外你可以认为原始数据不包含数字所有的数字只表示重复的次数 k 例如不会出现像 3a 或 2[4] 的输入。 方法栈保存局部数字和子串 # 栈保存局部数字和子串 def DecodeString(s):cur_num, cur_s 0, local_s []for i in range(len(s)):if s[i].isdigit(): # 判断数字cur_num 10 * cur_num int(s[i])elif s[i] [:local_s.append([cur_num, cur_s]) # 入栈数字和之前的子串cur_s, cur_num , 0elif s[i] ]:local_num, pre_s local_s.pop()cur_s pre_s local_num * cur_s # 右侧的cur_s是继[之后累加的子串左侧的pre_s是之前存下的子串else:cur_s s[i] # 累加包含总字符串和局部子串return cur_sprint(DecodeString(2[abc]3[cd]ef))
http://www.hkea.cn/news/14486202/

相关文章:

  • 装修 设计 网站轴承 网站建设 企炬
  • 做一个中英文双语网站建设多少钱注册国际贸易公司需要多少钱
  • 网站建设pdf 下载中山网站的优化
  • 现在公司做各网站要多少钱网站数据分析
  • 网站建设实训意义个人博客网站备案吗
  • 有哪些网站可以用免费 wordpress 主题
  • 网站建设需要哪些软件做系统去哪个网站好
  • 猪八戒网网站建设html5手机网站实例
  • 网站外链代发中国房产网
  • 网站开发工资多少钱老师直播课
  • 网页设计网站设计欣赏建材企业网站模板
  • 网站备案手续网址转化短链接
  • 网站集约化建设背景天津市中小企业局网站
  • 西宁网站建设君博推荐建站模板更改
  • 网站框架优化网站内链有什么用
  • 网站怎么添加流量长沙做网站公
  • 怎么做网站图标石景山网站制作建设公司
  • 天猫网站建设的目标做淘宝优惠券怎么有网站
  • 网站备份脚本友情链接平台网站
  • 如何查看网站 是哪家做的怎么做网站平台
  • 建设门户网站多少钱做网站的公司搞什么活动
  • 工商网上怎么申请注册公司网站如何做seo优化
  • cms网站开发php建设什么网站可以上传视频
  • 安徽省高等级公路工程建设指挥部网站wordpress 聊天室
  • 甘肃网站开发公司自己创做网站
  • 自己怎么做网站链接网站seo价格
  • 用word 做网站成都h5网站建设
  • ipad 设计网站wordpress时间有问题
  • 国家建设 免费论文期刊网站网站制作思路
  • 网站开发有哪些参考文献天津电力建设公司招标网站