力扣hot100——第1天:1两数之和、2两数相加、3无重复字符的最长子串

news2024/11/29 20:50:45

文章目录

  • 1.1两数之和【代码随想录已刷】
  • 2.2两数相加
    • 2.1.题目
    • 2.2.解答
  • 3.3无重复字符的最长子串
    • 3.1.题目
    • 3.2.解答

1.1两数之和【代码随想录已刷】

参考:力扣题目链接;自己的博客题解

2.2两数相加

参考:力扣题目链接;参考题解

2.1.题目

在这里插入图片描述

2.2.解答

这道题目的思路也非常简单,因为是倒序存储的数字,所以直接从尾巴的地方把两个数字相加,然后依次往后(也就是往高位)计算相加的结果即可,就是正常的加法运算。

所以程序只需要遍历两个链表,只要他们其中有一个不是空,就可以继续加结果:

  • 两个都不是空很好理解,就是两个数相加
  • 其中一个不是空,那么就是一个数位数更多,此时相加就只剩这个数所在的位

但是这里面有几个要注意的点:

  • 主要当前位置的加法结果是否有进位,也就是是否像高位进1,因此需要有一个变量存储进位结果;
  • 题目要求是新生成一个加法和的链表,所以不能修改给的两个链表,而是要自己新建一个链表;
  • 需要使用虚拟头结点来生成链表,这样新建节点的时候赋值给cur->next,这样更方便。否则如果赋值给cur->val,那么cur->next应该指向什么节点?这样就不方便操作了。

最后给出代码如下,非常简单:

struct ListNode
{
    int val;
    ListNode* next;

    ListNode(int val_) : val(val_), next(nullptr) {}
};

// 注意已经说的了l1/l2都不是空
ListNode *addTwoNumbers(ListNode *l1, ListNode *l2)
{
    // 使用虚拟头结点,方便处理
    ListNode* dummy = new ListNode(-1);   
    ListNode* cur = dummy;  
    int add = 0;   // 前一个节点相加是否有进位,如果有就是1,没有就是0

    // 开始逐个节点相加
    while(l1 || l2)
    {
        int val = 0;
        if(l1)
        {
            val += l1->val;
            l1 = l1->next;
        }
        if(l2)
        {
            val += l2->val;
            l2 = l2->next;
        }
        val += add;   // 加上上次进位的值
        cur->next = new ListNode(val % 10);  // 使用虚拟头节点,这里通过next来新建下一个节点
        add = val / 10;   // 本次进位结果
        cur = cur->next;  // 更新数组位置
    }
    
    // 最后一次相加的结果可能还有进位,但是被l1 || l2的判断条件忽略了,所以还要判断最后一次
    if(add)
        cur->next = new ListNode(1);  // 最后一个节点
    
    return dummy->next;   // 返回头节点
}

3.3无重复字符的最长子串

参考:力扣题目链接;参考题解

3.1.题目

在这里插入图片描述

3.2.解答

首先这道题目看最后的解释,这里说的是子串,而不是子序列。以字符串abcde为例,二者区别如下:

  • 子串:字符串,必须是相连的,比如abcbcd
  • 子序列:序列,可以跳着选择,比如abdace

这道题要求得是子串,所以可以使用滑动窗口算法,使用左右两个指针,然后用一个哈希表存储滑窗中已经有的元素。

  • 当右指针遍历到当前位置的元素的时候,从滑窗中寻找是否存在这个元素。如果存在,则一直移动滑窗的左指针,直到没有这个元素为止。
  • 此时滑窗中没有重复元素,使用左右指针计算滑窗长度,并更新最长的滑窗长度

右指针遍历到头之后,就找到了所有符合条件的(即没有重复字符)滑窗,也就找到了最终答案。

最后给出代码如下,很简单:

int lengthOfLongestSubstring(string s)
{
    unordered_set<char> uset;   // 存储滑窗中存在的字符
    int result = 0;  // 最长的长度
    int left = 0;    // [left, right]滑动窗口
    for(int right = 0; right < s.size(); right++)
    {
        // 如果滑窗中有这个字符,则一直移动左边界
        while(uset.find(s[right]) != uset.end()) 
            uset.erase(s[left++]);

        // 运行到这里,滑窗中没有重复的字符
        result = max(result, right - left + 1);  // 长度
        uset.insert(s[right]);   // 插入当前字符
    } 

    return result;
}

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

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

相关文章

【附源码】计算机毕业设计JAVA众筹平台网站

【附源码】计算机毕业设计JAVA众筹平台网站 目运行 环境项配置&#xff1a; Jdk1.8 Tomcat8.5 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技术&#xff1a; JAVA mybati…

什么是 游戏引擎 ?各个主流引擎的区别

在之前的元宇宙中有提及到游戏主播这个行业&#xff0c;那对应的就会有游戏开发者&#xff0c;对于开发最快捷的方式当然是使用游戏引擎进行开发了呀&#xff0c;那接下来我们就来说说这方面的内容吧 &#xff01; 本篇文章主要讲解&#xff0c;游戏开发中常用的5个游戏引擎及其…

C++——二叉搜索树

目录 二叉搜索树 二叉搜索树实现 非递归插入|非递归查找 删除 推导阶段 非递归删除代码 递归查找 递归插入 递归删除 析构函数 拷贝构造 赋值重载 完整代码 二叉搜索树的应用 Key/Value模型 二叉搜索树 二叉搜索树又称二叉排序树&#xff0c;它或者是一…

第3部分 静态路由

目录 3.1 静态路由与默认路由 3.1.1 静态路由介绍 3.1.2 默认路由介绍 3.2 静态路由命令汇总 转发数据包是路由器的最主要功能。路由器转发数据包时需要查找路由表&#xff0c;管理员可以通过手工的方法在路由器中直接配置路由表&#xff0c;这就是静态路由。虽然静态路由不…

Dialog的IDE搭建systermView的方法步骤(DA1469X)

1.背景 SystemView 是一个可以在线调试嵌入式系统的工具&#xff0c;它可以分析有哪些中断、任务执行了&#xff0c;以及这些中断、任务执行的先后关系。还可以查看一些内核对象持有和释放的时间点&#xff0c;比如信号量、互斥量、事件、消息队列等。这在开发和处理具有多个线…

大规模 MIMO 检测的近似消息传递 (AMP)附Matlab代码

✅作者简介&#xff1a;热爱科研的Matlab仿真开发者&#xff0c;修心和技术同步精进&#xff0c;matlab项目合作可私信。 &#x1f34e;个人主页&#xff1a;Matlab科研工作室 &#x1f34a;个人信条&#xff1a;格物致知。 更多Matlab仿真内容点击&#x1f447; 智能优化算法 …

神经架构搜索的综合调查:挑战和解决方案(一)

神经架构搜索的综合调查&#xff1a;挑战和解决方案 paper题目&#xff1a;A Comprehensive Survey of Neural Architecture Search: Challenges and Solutions paper是西北大学发表在ACM Computing Surveys 2021的工作 paper地址&#xff1a;链接 ABSTRACT 深度学习以其强大的…

c#机器学习之opencv(2)-Mat基础

目录Mat基础Mat本质copyTo与cloneMat基础 opencv将图像数据存在一个二维矩阵里。 下面代码复制了一个图像矩阵。 Mat srcPic new Mat("test1.png", ImreadModes.Color); Mat aPic new Mat(srcPic,new OpenCvSharp.Rect(100,120, srcPic.Width-100, srcPic.Heigh…

1.8 打好shell基础

一、常用shell命令 1、管道命令 &#xff08;1&#xff09;命令格式 &#xff08;2&#xff09;案例演示 任务1、查看/etc目录信息前5行信息 执行命令&#xff1a;ll /etc | head -5 任务2、查看/etc/profile文件后5行信息 执行命令&#xff1a;cat /etc/profile | tai…

大数据培训FileInputFormat实现类

FileInputFormat实现类 思考:在运行MapReduce程序时&#xff0c;输入的文件格式包括:基于行的日志文件、 二进制格式文件、数据库表等。那么&#xff0c;针对不同的数据类型&#xff0c;MapReduce是如 何读取这些劣如据的呢? FileInputFormat常见的接口实现类包括:TextInputF…

mapreduce搭建

一.虚拟机安装CentOS7并配置共享文件夹 二.CentOS 7 上hadoop伪分布式搭建全流程完整教程 三.本机使用python操作hdfs搭建及常见问题 四.mapreduce搭建 五.mapper-reducer编程搭建 mapreduce搭建一、配置1.创建mapred-site.xml文件2.编辑mapred-site.xml二、打开hadoop0.删除da…

virtio-net 实现机制【一】(图文并茂)

1. 基于virtio的半虚拟化概述 1.1 virtio运行结构 ① virtio表示虚拟化IO&#xff0c;用于实现设备半虚拟化&#xff0c;即虚拟机中运行的操作系统需要加载特殊的驱动&#xff08;e.g. virtio-net&#xff09;且虚拟机知道自己是虚拟机 相较于基于完全模拟的全虚拟化&#xf…

PR-视频加介绍背景

每天一个PS/PR小技巧&#xff08;原理实践&#xff09; 比如我们有一个展示视频&#xff0c;我们希望在视频一开始时添加一个介绍背景&#xff08;纯色背景&#xff09;&#xff1a; 点击新建->颜色遮罩&#xff1a; 定义名称&#xff0c;选择颜色&#xff0c;然后就能在工…

Bug: conda环境与jupyter notebook kernel核环境不一致

问题 一般在服务器上进行环境安装的时候有多种方式&#xff0c;比如docker, conda等。conda肯使用起来更加简便&#xff0c;docker更适合服务器部署的时候使用。 本文记录在使用conda时候出现的问题&#xff0c;jupter notebook中的环境不一致导致的。 首先conda创建环境 co…

蓝桥杯嵌入式第二篇配置按键

文章目录前言一、原理图查看二、cubeMX配置三、代码讲解(使用按键控制LED灯的开关)四、HAL_Delay的内部实现五.遗留的问题总结前言 点完灯后接下来我们就开始按键的学习了&#xff0c;这也是很简单的&#xff0c;大家不用担心。 一、原理图查看 可以看到板子上面是有4个按键…

定时任务多线程-springboot

定时任务 在项目开发过程中&#xff0c;经常需要定时任务来帮助我们实现某些业务功能&#xff0c;比如定时生成数据报表、生成对账单、订单超时处理等。Spring Boot提供了内置的Scheduled注解实现定时任务的功能。 步骤 1.修改启动类 在启动类上加上EnableScheduling开启定时…

华为数字化转型之道 方法篇 第五章 视IT为投资,用产品思维管理IT

第五章 视IT为投资,用产品思维管理IT 5.1 数字时代IT系统的重新定位 比较传统信息化和数字化转型下的IT系统特征,我们发现业务环境、IT能力、业务和IT的关系都发生了巨大的变化(见图5-1) 从“管理系统”到“作业平台” 传统信息化下的IT系统往往侧重于信息记录、流程固化…

LeetCode994. 腐烂的橘子(C++中等题)

题目 在给定的 m x n 网格 grid 中&#xff0c;每个单元格可以有以下三个值之一&#xff1a; 值 0 代表空单元格&#xff1b; 值 1 代表新鲜橘子&#xff1b; 值 2 代表腐烂的橘子。 每分钟&#xff0c;腐烂的橘子 周围 4 个方向上相邻 的新鲜橘子都会腐烂。 返回 直到单元格…

因子模型:协方差矩阵

本文是Quantitative Methods and Analysis: Pairs Trading此书的读书笔记。 因子协方差矩阵&#xff08;factor covariance matrix&#xff09;在计算风险的时候很重要。如果一个模型有个因子&#xff0c;那么协方差矩阵的大小就是。对角线元素是每个因子的方差&#xff0c;非…

[附源码]Python计算机毕业设计SSM流浪动物管理系统(程序+LW)

项目运行 环境配置&#xff1a; Jdk1.8 Tomcat7.0 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技术&#xff1a; SSM mybatis Maven Vue 等等组成&#xff0c;B/S模式 M…