leetcode之hot100---206环形链表(C++)

ops/2024/12/23 15:07:01/

思路一:哈希表

遍历链表,同时借助哈希表判断当前遍历到的节点是否已经被访问过,如果当前节点已被访问过,则说明存在环

/*** Definition for singly-linked list.* struct ListNode {*     int val;*     ListNode *next;*     ListNode(int x) : val(x), next(NULL) {}* };*/
class Solution {
public:bool hasCycle(ListNode *head) {// 空链表或只有一个节点,必定没有环if (head == nullptr || head->next == nullptr) {return false;}// 使用哈希表存储已访问的节点地址unordered_map<ListNode*, bool> visited;// 遍历链表ListNode* temp = head;while (temp != nullptr) {// 如果当前节点已被访问过,则说明存在环if (visited.find(temp) != visited.end()) {return true;}// 标记当前节点为已访问visited[temp] = true;temp = temp->next;}// 遍历结束,没有发现环return false;}
};
  • 时间复杂度:O(N)
  • 空间复杂度:O(N)

思路二:快慢指针

使用两个指针分别同时遍历链表,一个指针每次移动两个距离(称为快指针),另一个指针每次移动一个距离(称为慢指针),当快指针反过来追上慢指针时说明链表中出现了环

/*** Definition for singly-linked list.* struct ListNode {*     int val;*     ListNode *next;*     ListNode(int x) : val(x), next(NULL) {}* };*/
class Solution {
public:bool hasCycle(ListNode *head) {// 空链表或只有一个节点,必定没有环if (head == nullptr || head->next == nullptr) {return false;}//快慢指针初始化ListNode* slow = head;ListNode* fast = head->next;while(slow != fast){//快指针遍历了整个链表也没有追上慢指针,说明链表中不存在环if(fast == nullptr || fast->next == nullptr){return false;}//快慢指针进行移动slow = slow->next;fast = fast->next->next;}return true;}
};
  • 时间复杂度:O(N)
  • 空间复杂度:O(1)

http://www.ppmy.cn/ops/144324.html

相关文章

WPF MVVM 数据表格DataGrid的表头Header无法进行数据绑定

话不多说&#xff0c;直接上案例代码&#xff0c;因为我也不知道为什么不能进行数据绑定。 DataGrid <DataGrid ColumnHeaderHeight"55"ItemsSource"{Binding BottomFormingMolds}" SelectedItem"{Binding SelectedItem3,ModeTwoWay}" …

在 .NET 5.0 运行 .NET 8.0 教程:使用 ASP.NET Core 创建 Web API

前言 因为我本机安装的是vs2019&#xff0c;所以我在使用vs创建项目的时候&#xff0c;只能选择.NET 5.0&#xff0c;而无法选择.NET 8.0 在网上有看到说用vs2019使用.net 8.0 &#xff0c;但是感觉不可靠&#xff0c;要用还是安装vs2022吧。 我因为不想要安装vs2022。 但是微…

半导体制造技术导论(第二版)萧宏 第十二章 化学机械研磨工艺

本章要求 1.列出化学机械研磨工艺的应用 化学机械研磨是一种移除工艺技术&#xff0c;结合化学反应和机械研磨去除沉积的薄膜&#xff0c;使表面更加平滑和平坦&#xff1b;也用于移除表面上大量的电介质薄膜&#xff0c;并在硅衬底上形成浅沟槽隔离STI&#xff1b;还可以从晶圆…

基于RocksDB编写一个简单的SQL数据库|得物技术

一、前言 数据库DBMS是当前互联网开发者最熟悉的基础设施之一&#xff0c;很多后端开发者的入门项目就是一个简单的基于MySQL的数据管理系统。笔者一直想自己编写一个简单的SQL数据库&#xff0c;正好最近正在学习RocksDB和Zig语言的内容&#xff0c;就想利用这个机会作为学习…

List深拷贝后,数据还是被串改

List深拷贝后数据还是被串改 List newList new ArrayList<>(oldList)newList.pushAll(oldList)你甚至想到了java8streamAPI以上还不行 List newList new ArrayList<>(oldList) 这是采用构造参数做到的深拷贝&#xff0c;是没问题的 newList.pushAll(oldList) …

docker打包镜像并迁移:如何从A服务器打包docker镜像到B服务器上容器中运行

1.在A服务器上&#xff0c;查看docker镜像 docker images会显示当前的服务器上已有的镜像 2.在A服务器上&#xff0c;将所需要的镜像打包 docker save -o shuai_docker.tar xxx(镜像名):vxx(镜像版本)会出现&#xff1a;xxxxx:Loading layer [>] xxkB/xxkB字样 3.将shua…

C++打造局域网聊天室第十二课: 客户端和服务端的切换

文章目录 前言一、补充说明二、客户端和服务端身份状态的切换三、点击关闭窗口按钮总结 前言 C打造局域网聊天室第十二课&#xff1a; 客户端和服务端的切换 一、补充说明 在C打造局域网聊天室第十一课&#xff1a; 程序关闭及线程的结束中描述的服务端线程的关闭和结束是存在…

了解 SpringMVC 请求流程

文章目录 1. Spring 基础 - SpringMVC 请求流程1.1 引入1.2 什么是 MVC1.3 什么是 Spring MVC1.4 请求流程核心架构的具体流程步骤补充 1.5 案例**Maven 包引入****业务代码的编写**DaoServiceControllerwebapp 下的 web.xmlspringmvc.xmlJSP 视图 2. Spring 进阶 - Dispatcher…