力扣hot100——第1天:1两数之和、2两数相加、3无重复字符的最长子串
创始人
2024-03-03 21:34:53
0

文章目录

  • 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 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;
}

相关内容

热门资讯

AWSECS:访问外部网络时出... 如果您在AWS ECS中部署了应用程序,并且该应用程序需要访问外部网络,但是无法正常访问,可能是因为...
AWSElasticBeans... 在Dockerfile中手动配置nginx反向代理。例如,在Dockerfile中添加以下代码:FR...
AWR报告解读 WORKLOAD REPOSITORY PDB report (PDB snapshots) AW...
AWS管理控制台菜单和权限 要在AWS管理控制台中创建菜单和权限,您可以使用AWS Identity and Access Ma...
北信源内网安全管理卸载 北信源内网安全管理是一款网络安全管理软件,主要用于保护内网安全。在日常使用过程中,卸载该软件是一种常...
​ToDesk 远程工具安装及... 目录 前言 ToDesk 优势 ToDesk 下载安装 ToDesk 功能展示 文件传输 设备链接 ...
Azure构建流程(Power... 这可能是由于配置错误导致的问题。请检查构建流程任务中的“发布构建制品”步骤,确保正确配置了“Arti...
群晖外网访问终极解决方法:IP... 写在前面的话 受够了群晖的quickconnet的小水管了,急需一个新的解决方法&#x...
AWSECS:哪种网络模式具有... 使用AWS ECS中的awsvpc网络模式来获得最佳性能。awsvpc网络模式允许ECS任务直接在V...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...