Day03 leecode#有效的括号#合并两个有序链表

news2025/2/24 12:20:31

题目描述:

有效的括号
给定一个只包括 ‘(’,’)’,’{’,’}’,’[’,’]’ 的字符串 s ,判断字符串是否有效。

有效字符串需满足:

左括号必须用相同类型的右括号闭合。
左括号必须以正确的顺序闭合。

题目解读:判断字符串s中的符号能不能配对,符号取出放入栈中,配成功的弹出栈,最后判断栈为空就是真,此外当s中个数为奇数一定不行

初级代码:

class Solution:
    def isValid(self, s: str) -> bool:
        stack = []
        for i in s:
            if i == '(':
                stack.append('(')
            elif i == '[':
                stack.append('[')
            elif i == '{':
                stack.append('{')
            if not stack:
                return False
            if i == ')':
                if stack[-1] == '(':
                    stack.pop()
                else:
                    return False
            elif i == ']':
                if stack[-1] == '[':
                    stack.pop()
                else:
                    return False
            elif i == '}':
                if stack[-1] == '{':
                    stack.pop()
                else:
                    return False
        if len(stack) != 0:
            return False
        return True

技巧,在遍历到左括号时,对应的右括号入栈!在之后遍历到右括号的时候,只需要比较当前右括号和栈顶元素想不想等就可以了,比左括号直接入栈实现起来要简单不少。

class Solution:
    def isValid(self, s: str) -> bool:
        stack = []

        for item in s:
            if item == '(':
                stack.append(')')
            elif item == '[':
                stack.append(']')
            elif item == '{':
                stack.append('}')
            elif not stack or stack[-1] != item:
                return False
            else:
                stack.pop()

        return True if not stack else False

加字典实现:

class Solution:
    def isValid(self, s: str) -> bool:
        if len(s) % 2 == 1:
            return False

        pairs = {
            ")": "(",
            "]": "[",
            "}": "{",
        }
        stack = list()
        for ch in s:
            if ch in pairs:                                   
                if not stack or stack[-1] != pairs[ch]:
                    return False
                stack.pop()
            else:
                stack.append(ch)

        return not stack

#not stack 是一个布尔表达式,代表栈为空,stack[-1]!=pairs(ch) 代表栈顶元素不匹配 pairs(ch),也就是说,ch 是右括号,stack[-1]代表的左括号与ch不匹配

题目描述:

将两个升序链表合并为一个新的 升序 链表并返回。新链表是通过拼接给定的两个链表的所有节点组成的。 

 分析:1、暴力解法

                逐一比较,取最小值

代码:

class Solution:
    def mergeTwoLists(self, l1: ListNode, l2: ListNode) -> ListNode:
        if l1 is None:
            return l2
        elif l2 is None:
            return l1
        elif l1.val < l2.val:
            l1.next = self.mergeTwoLists(l1.next, l2)  #相当于一个循环
            return l1
        else:
            l2.next = self.mergeTwoLists(l1, l2.next)
            return l2

elif里面自己调用自己函数,相当于循环

val()函数的功能为:将一组字符型数据的数字部分转换成相应的数值型数据

next相当于链表接下去后面只想哪 

小的链表指向大的,当其中一个链表为空,停止

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/10313.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

大模型相关资料整理

1. 大模型的挑战 GPT-3 175B模型的参数如下&#xff1a; 网络层&#xff08;Number of layers&#xff09;: 96 句子长度&#xff08;Sequence length&#xff09;: 2048 隐藏层大小&#xff08;Hidden layer size&#xff09;: 12288 词汇表&#xff08;Vocabulary size&#…

java高级--SpringBoot篇

目录 一、什么是SpringBoot 二、SpringBoot的特点 三、springboot快速入门 四、介绍配置文件的种类 五、开发环境配置文件的切换 六、读取springboot配置文件中的内容 七、Springboot注册web三大组件 八、SpringBoot的底层原理 8.1 包扫描的原理 8.2 springboot自动装配原理…

如何备考高级软考的系统架构设计师?

架构设计师是软考高级科目&#xff0c;比较难&#xff0c;每一年的通过率在15%左右。 不过软考它的特点是考察的深度不深&#xff0c;但是范围比较广&#xff0c;特别是高级&#xff0c;对项目经验比较看重&#xff0c;如果没有项目经验的朋友&#xff0c;一定要多准备项目素材…

springboot10:web开发常用功能(拦截器,文件上传,异常处理)

一.拦截器 1.使用 访问任何请求&#xff0c;都只有登录才能访问&#xff0c;挨个写入请求太困难&#xff0c;使用拦截器机制handlerIntercepter&#xff08;prehandle方法&#xff0c;posthandle方法,afterCompletion方法&#xff09;编写一个拦截器实现handlerInterceptor接…

算法与数据结构 - 字节跳动笔试题

😄这里将持续更新接下来做过的字节跳动公司相关的笔试题,包括网上收集的秋春招笔试题、以及自己参加的字节举办的编程赛的题目。 🚀导航: ID题目描述NO.1小红走迷宫简单、按逻辑写即可ACNO.2铺水管dfs回溯、注意剪枝才能ACNO.3喵汪故事借助二分才能ACNO.4小超的游戏pytho…

学术论文写作以及discussions/results与conclusion的区别

经验帖 | 如何写SCI论文&#xff1f; Result、Discussion和Conclusion区别解析 如何写学术论文 一篇论文只能有一个主题&#xff0c;不能出现过多的研究问题&#xff0c;这样只会让文章读起来很乱。就像大牛经常讲的&#xff0c;“one paper, one story”&#xff0c;一篇论文…

unix/linux make

GNU:make 参考文档 程序的编译和链接 一般来说&#xff0c;无论是C还是C&#xff0c;首先要把源文件编译成中间代码文件&#xff0c;在Windows下也就是 .obj 文件&#xff0c;UNIX下是 .o 文件&#xff0c;即Object File&#xff0c;这个动作叫做编译&#xff08;compile&…

HummerRisk V0.5.1 发布:新增对象存储、优化K8s 资源态势和资源拓扑等

HummerRisk V0.5.1 发布&#xff1a;新增对象存储对接查看功能&#xff0c;增加 K8s 资源的部署信息查看&#xff0c;深度优化K8s 资源拓扑&#xff0c;并优化了镜像检测、云检测及资源态势同步等多个内容。 感谢社区中小伙伴们的反馈&#xff0c;你们的认可是我们前进的动力。…

java中的函数式接口是什么?

问题现象&#xff1a; 最近在复习java基础知识&#xff0c;发现了一个面试题&#xff1a; java中的函数式接口是什么&#xff1f; 问题分析&#xff1a; 老实说&#xff0c;我一开始看到“函数式接口”这个术语&#xff0c;愣了一下&#xff1a; java中的函数式接口是什么&…

移动WEB开发之流式布局--二倍图

物理像素&物理像素比 物理像素点指的是屏幕显示的最小颗粒&#xff0c;是物理真实存在的。这是厂商在出厂时就设置好了,比如苹果6\7\8 是 750* 1334 物理像素比就是屏幕的分辨率&#xff0c;分辨率越高&#xff0c;显示越清楚&#xff0c;750* 1334就是横的有750的像素点…

运行mbedtls自带Demo ssl_client的记录

概述&#xff1a; 运行mbedtls自带 ssl demo的记录&#xff1b; 操作过程&#xff1a; 编译Demo&#xff0c;请看我专栏中的相关文章 先运行服务端程序&#xff0c;运行ssl_server.exe&#xff0c;运行结果如下&#xff1a; mbedtls-3.2.1\mbedtls-3.2.1\programs\ssl> .…

目标检测论文解读复现之九:基于改进YOLOv5的复杂场景下SAR图像船舶检测方法

前言 此前出了目标改进算法专栏&#xff0c;但是对于应用于什么场景&#xff0c;需要什么改进方法对应与自己的应用场景有效果&#xff0c;并且多少改进点能发什么水平的文章&#xff0c;为解决大家的困惑&#xff0c;此系列文章旨在给大家解读最新目标检测算法论文&#xff0…

Linux:shell编程(内含:1.shell简介+2.shell实操+3.shell的变量介绍+4.shell变量的定义)

1.shell简介&#xff1a; 解释&#xff1a;界面编写各种命令时&#xff0c;需要一个解释器&#xff0c;解释器先执行后给linux。执行完之后&#xff0c;结果返回给界面。经常使用的是bash。 注&#xff1a;若界面执行的命令比较复杂&#xff0c;可以写一个脚本&#xff0c;xxx…

医疗健康产品展:联影医疗

​ 国内医疗健康行业的独角兽公司&#xff08;估值超10亿&#xff09; 联影医疗 1 基本信息 联影医疗是一家医疗设备和医疗信息化解决方案提供商&#xff0c;为医疗机构提供涵盖影像诊断设备、放疗设备、服务培训、医疗IT的全方位医疗解决方案。 联影筹建于2010年10月&…

第七章 树与森林

树与森林 7.1树的概念与表示 7.1.1树的定义及相关术语 1&#xff0e;树的定义 ​ 树&#xff08;Tree&#xff09;是n&#xff08;n≥0&#xff09;个有限数据元素的集合。当n&#xff1d;0时&#xff0c;称这棵树为空树。在一棵非树T中&#xff1a; ​ ⑴有一个特殊的数据…

算法常见高数知识

文章目录1. 偏微分方程和常微分方程1.1 偏微分1.2 常微分2. 表示方法&#xff08;名词/notation&#xff09;2.1 莱布尼兹表示3. 空间直线及其方程4. 方向向量4.1 两点求方向向量高数课本(有目录)可以看这个链接&#xff1a;1. 高等数学第六版.同济大学数学系.扫描版.pdf 1. 偏…

《InnoDB引擎‍》 MySQL缓存池

‍MySQL缓存池 InnoDB存储引擎是基于磁盘存储的&#xff0c;并将其中记录按照页的方式进行管理。因此可以将其视为基于磁盘的数据库。 在数据库系统中&#xff0c;由于CPU速度和磁盘速度之间的鸿沟&#xff0c;基于磁盘的数据库系统通常使用缓冲池技术来提高数据库整体性能。 缓…

阿里P8MySQL,基础/索引/锁/日志/调优都不误,一锅深扒端给你

阿里P8MySQL&#xff0c;你知道都问些啥吗&#xff1f;昨天小编特意去搜集了一些MySQLP8问题&#xff0c;经过整理归纳分为基础、索引、锁、日志、调优、开放问题等等168道题目&#xff0c;拿出这些题来测试一下自己水平可否&#xff1f;&#xff1f;&#xff1f; 先上一张MySQ…

Tomcat 源码解析一请求处理的整体过程-黄泉天怒(上)

本博客的很多的理论知识都来源于 《Tomcat内核设计剖析》这本书&#xff0c;大家的兴趣去读这本书&#xff0c;对于想了解Tomcat源码的小伙伴&#xff0c;肯定对你有所帮助 &#xff0c;但是想自己有亲身体会的话&#xff0c;还是要深入源码。 不然知道这些理论的知识&#xff…

Java面向对象:封装

1.封装&#xff1a; 面向对象的三大特征&#xff1a; 封装、继承、多态 它是什么&#xff1a; 封装&#xff1a;告诉我们&#xff0c;如何正确设计对象的属性和方法。 封装的原则&#xff1a;对象代表什么&#xff0c;就得封装对应数据&#xff0c;并提供数据对应的行为。 …