数据结构:力扣OJ题

目录

​编辑题一:链表分割

思路一:

题二:相交链表

思路一:

题三:环形链表

 思路一:

题四:链表的回文结构

思路一:

链表反转:

查找中间节点:

本人实力有限可能对一些地方解释的不够清晰,可以自己尝试读代码,望海涵!


题一:链表分割

现有一链表的头指针 ListNode* pHead,给一定值x,编写一段代码将所有小于x的结点排在其余结点之前,且不能改变原来的数据顺序,返回重新排列后的链表的头指针。

思路一:

1.分别创建一个记录小于x的“小”结构体,和记录大于等于x的“大”结构体

2.然后malloc函数动态开辟一个结构体大小的空间,这时head和tail都指向同一位置,将phead->val与x比较,小于想,放入less中,大于等于x放入great中,

3.当phead为NULL时,将两个“大”“小”结构体链接起来,记录lesshead节点,然后free释放开辟的动态内存空间,返回记录lesshead的地址。

    ListNode* partition(ListNode* phead, int x) {struct ListNode* head = phead ; struct ListNode* lesshead ;struct ListNode* greathead ; struct ListNode* lesstail ; struct ListNode* greattail ; //动态开辟空间lesshead = lesstail = (struct ListNode*)malloc(sizeof(struct ListNode));greathead = greattail = (struct ListNode*)malloc(sizeof(struct ListNode));while(head){//小于x的尾插到lessTailif(head->val < x){lesstail->next  = head;lesstail = lesstail->next;            }//大于等于x的尾插到greaterTailelse{greattail->next  = head;greattail = greattail->next; }//下一个位置head = head->next;  }//小的接上大的lesstail->next = greathead->next;greattail->next = NULL;//新头节点struct ListNode* Phead = lesshead->next;//销毁free(lesshead);free(greathead);return Phead;}

题二:相交链表

给你两个单链表的头节点 headA 和 headB ,请你找出并返回两个单链表相交的起始节点。如果两个链表不存在相交节点,返回 null 。

图示两个链表在节点 c1 开始相交

题目数据 保证 整个链式结构中不存在环。

注意,函数返回结果后,链表必须 保持其原始结构 。

思路一:

1.先分别将A和B遍历一遍,计算出长度len
2.计算长度差Slen,让长的先指向Slen个next位置
3.此时再同时遍历,直到A和B的地址相同
4.返回的就是第一个交点

 

struct ListNode *getIntersectionNode(struct ListNode *headA, struct ListNode *headB) 
{struct ListNode* curA = headA,*curB = headB;int len1 = 1,len2 = 1; //计算链表长度while(curA){curA = curA->next;len1++;}while(curB){curB = curB->next;len2++;}//如果此时遍历结束地址不相等,说明没有相交点if(curA != curB){return NULL;}//abs是计算差值绝对值函数int Slen = abs(len1 - len2);//二次遍历的长短链表struct ListNode* longlist = headA,*shortlist = headB;if(len1 <  len2){longlist = headB;shortlist = headA;}//让longlist和shortlist的长度相同while(Slen--){longlist = longlist->next;}//找到第一个交点while(longlist != shortlist){longlist = longlist->next;shortlist = shortlist->next;}//输出交点地址return longlist;
}

题三:环形链表

给你一个链表的头节点 head ,判断链表中是否有环。

如果链表中有某个节点,可以通过连续跟踪 next 指针再次到达,则链表中存在环。 为了表示给定链表中的环,评测系统内部使用整数 pos 来表示链表尾连接到链表中的位置(索引从 0 开始)。注意:pos 不作为参数进行传递 。仅仅是为了标识链表的实际情况。

如果链表中存在环 ,则返回 true 。 否则,返回 false 。

示例 1:

 思路一:

快慢指针思路:
1.创建快慢指针fast和slow;
2.开始位置相同,slow每次指向下一个地址, fast每次指向下下个地址;
3.循环判断,直到slow=fast地址相同

4,相同则说明链表存在环
反之,fast或fast->next尾NULL则不存在环

bool hasCycle(struct ListNode *head)
{struct ListNode* slow = head;struct ListNode* fast = head;//fast或fast->next尾NULL则不存在环while(fast && fast->next){//slow每次指向下一个地址, fast每次指向下下个地址slow = slow->next;fast = fast->next->next;//相同则说明链表存在环if(slow == fast){return true;}}return false;
}

题四:链表的回文结构

思路一:

如下:两种方法,得到的节点去循环判断,如果newnode或者head一个为NULL,则说明是回文结构,如果在循环中结束·,则不是回文结构。

链表反转:

三个变量n1=NULL,n2=head,n3,如果n2不为NULL,则n3=n2->next,循环如果n2为NULL,就停下来,当n3为空时n3就不进行变化,最后n1会停在最后一个位置,这个时候逆置完成。

查找中间节点:

分别定义快慢两个指针,快指针一次前进两个地址,慢指针一次前进一个地址,当奇数时快指针的next为NULL时,当链表为偶数时判断条件为地址为NULL,停下来,此时慢指针就在链表中间节点上。

//将链表反转
struct ListNode* reverseList(struct ListNode* head)
{struct ListNode* n1,*n2,*n3;n1 = NULL;n2 = head;if(n2)n3 = n2->next;while(n2){n2->next = n1;n1 = n2;n2 = n3;if(n3)n3 = n3->next;}return n1;
}
//得到链表中间节点
struct ListNode* middleNode(struct ListNode* head)
{struct ListNode* slow = head;struct ListNode* fast = head;while(fast && fast->next){slow = slow->next;fast = fast->next->next;}return slow;
}
class PalindromeList {
public:bool chkPalindrome(ListNode* head) {struct ListNode* mid = middleNode(head);struct ListNode* newnode = reverseList(mid);//一个为空自己退出while(newnode && head){//不相同,则不是回文结构if(newnode->val != head->val){return false;}newnode = newnode->next;head = head->next; }return true;}
};

本人实力有限可能对一些地方解释的不够清晰,可以自己尝试读代码,望海涵!

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

数字鸿沟,让气候脆弱者更脆弱

“从小到大完全没敢想&#xff0c;也觉得是不可思议的一件事儿&#xff0c;发洪水发到家门口了”&#xff0c;前两天&#xff0c;一位门头沟土著友人&#xff0c;给我发来了这句话。 气候变化正在影响整个地球&#xff0c;面对一连串前所未见的极端天气灾害&#xff0c;很多人应…

CCLINK IE FIELD BASIC转MODBUS-TCP网关cclink与以太网的区别

协议的不同&#xff0c;数据读取困难&#xff0c;这是很多生产管理系统的难题。但是现在&#xff0c;捷米JM-CCLKIE-TCP通讯网关&#xff0c;让这个问题变得非常简单。这款通讯网关可以将各种MODBUS-TCP设备接入到CCLINK IE FIELD BASIC网络中&#xff0c;连接到MODBUS-TCP总线…

运营商加速抢占云计算,5G带来更多利润,上半年躺赚近千亿

中国移动已率先公布了上半年的业绩&#xff0c;业绩显示它们正在加速抢占此前由互联网企业占据优势的云计算市场&#xff0c;不过最让它们开心的还是5G继续带动利润的高速增长&#xff0c;预计三大运营商今年上半年可以躺赚近千亿元。 中国移动无疑仍然是运营商行业的领头羊&am…

视觉学习(七)---Flask 框架下接口调用及python requests 实现json字符串传输

在项目实施过程中需要与其他系统进行接口联调&#xff0c;将图像检测的结果传递给其他系统接口&#xff0c;进行逻辑调用。这中间的过程可以通过requests库进行实现。 1.安装requests库 pip install requests2.postman 接口测试 我们先通过postman 了解下接口调用&#xff0…

论文笔记--Llama 2: Open Foundation and Fine-Tuned Chat Models

论文笔记--Llama 2: Open Foundation and Fine-Tuned Chat Models 1. 文章简介2. 文章概括3 文章重点技术3.1 预训练Pretraining3.1.1 预训练细节3.1.2 Llama2模型评估 3.2 微调Fine-tuning3.2.1 Supervised Fine-Tuning(FT)3.2.2 Reinforcement Learning with Human Feedback(…

树莓派RP2040 用Arduino IDE安装和编译

目录 1 Arduino IDE 1.1 IDE下载 1.2 安装 arduino mbed os rp2040 boards 2 编程-烧录固件 2.1 打开点灯示例程序 2.2 选择Raspberry Pi Pico开发板 2.3 编译程序 2.4 烧录程序 2.4.1 Raspberry Pi Pico开发板首次烧录提示失败 2.4.2 解决首次下载失败问题 2.4.2.1…

谈谈什么是云计算?以及它的应用

作者&#xff1a;Insist-- 个人主页&#xff1a;insist--个人主页 作者会持续更新网络知识和python基础知识&#xff0c;期待你的关注 目录 ​编辑 一、什么是云计算 二、云计算的优势与劣势&#xff1f; 1、云计算的优势 ①提高资源利用率 ②提升效率 ③降低成本 2、云…

【100天精通python】Day32:使用python操作数据库_MySQL下载、安装、配置、使用实战

目录 专栏导读 1 MySQL概述 2 MySQL下载安装 2.1 下载 2.2 安装 2.3 配置 2.3.1 服务类型和网络配置&#xff1a; 2.3.2 连接配置&#xff1a; 2.3.3 账户和权限配置&#xff1a; 2.3.4 配置Windows Service &#xff1a; 2.3.5 服务器文件权限配置&#xff1a; 2.3…

单片机直驱两相四线步进电机研究

【本文发布于https://blog.csdn.net/Stack_/article/details/132236329&#xff0c;未经允许不得转载&#xff0c;转载须注明出处】 双极性步进电机&#xff08;两相四线步进电机&#xff09;&#xff0c;原理的东西就先不讲太多了&#xff0c;还没搞清楚&#xff0c;边查资料边…

VMware 16 Pro将电脑里的文件移动到虚拟机中【附带可能出现的问题和解决】

VMware 16 Pro将电脑里的文件移动到虚拟机中 1.使用VM tools 打开VM ware会出现下面的&#xff0c;直接点击安装。 点击下一步 选哪个都行 之后会重启虚拟机&#xff0c;然后就可以使用了。 我没有程序可以打开压缩包&#xff0c;显示我的虚拟机网络没法用&#xff0c;点击…

【软件工程】数据流图/DFD概念符号/流程图分层/数据字典

【软件工程】数据流图/DFD概念符号/流程图分层/数据字典 目录 【软件工程】数据流图/DFD概念符号/流程图分层/数据字典 一、数据流图 ( DFD ) 简介 二、数据流图 ( DFD ) 概念符号 1、数据流 2、加工 ( 核心 ) 3、数据存储 4、外部实体 三、数据流图 ( DFD ) 分层 1、…

【深度学习 | 反向传播】释放反向传播的力量: 让训练神经网络变得简单

&#x1f935;‍♂️ 个人主页: AI_magician &#x1f4e1;主页地址&#xff1a; 作者简介&#xff1a;CSDN内容合伙人&#xff0c;全栈领域优质创作者。 &#x1f468;‍&#x1f4bb;景愿&#xff1a;旨在于能和更多的热爱计算机的伙伴一起成长&#xff01;&#xff01;&…

阿里云服务器搭建WordPress建站教程基于Windows系统

本教程是使用阿里云服务器镜像系统选择的是Windows操作系统&#xff0c;手动安装WordPress博客网站全过程。本教程介绍如何在Windows操作系统的ECS实例上搭建WordPress网站。 目录 准备工作 搭建WordPress网站 解析WordPress网站域名 准备工作 创建Windows操作系统的ECS实…

BGP协议综合知识(打破水平分割--联邦、反射规则)

反射规则&#xff1a;不优路由不能被传递&#xff0c;自然也不能被反射&#xff1b; RR从一个EBGP邻居处学习到的路由&#xff0c;可以传输给客户端、非客户端&#xff0c;已经本地的其他EBGP邻居&#xff1b;RR从一个客户端学习到的路由&#xff0c;可以传递给本地其他的客户…

通讯协议037——全网独有的OPC HDA知识一之聚合(六)实际时间最小值

本文简单介绍OPC HDA规范的基本概念&#xff0c;更多通信资源请登录网信智汇(wangxinzhihui.com)。 本节旨在详细说明HDA聚合的要求和性能。其目的是使HDA聚合标准化&#xff0c;以便HDA客户端能够可靠地预测聚合计算的结果并理解其含义。如果用户需要聚合中的自定义功能&…

7.3 详解NiN模型--首次使用多层感知机(1x1卷积核)替换掉全连接层的模型

一.前提知识 多层感知机&#xff1a;由一个输入层&#xff0c;一个或多个隐藏层和一个输出层组成。&#xff08;至少有一个隐藏层&#xff0c;即至少3层&#xff09; 全连接层&#xff1a;是MLP的一种特殊情况&#xff0c;每个节点都与前一层的所有节点连接&#xff0c;全连接…

分布式数据库的HTAP能统一OLTP和 OLAP吗?

OLAP和OLTP通过ETL衔接。为提升OLAP性能&#xff0c;需在ETL过程进行大量预计算&#xff0c;包括&#xff1a; 数据结构调整业务逻辑处理 好处&#xff1a;可控制OLAP的访问延迟&#xff0c;提升用户体验。但因为要避免抽取数据影响OLTP系统&#xff0c;须在日终的交易低谷期…

java Spring Boot yml多环境配置

我们项目 线上和线下 环境配置不是特别一样 例如 运行的URL 数据库地址 数据库的账号密码 这些经常是不一样的 如果每次上线钱改 也不是特别方便 甚至可能忘记 那么 进入我们代码中 所谓的多环境 就是在不同的环境下配置不同的值 终端还是在application配置文件中 多环境的话…

Add-in Express for Microsoft Office and Delphi Crack

Add-in Express for Microsoft Office and Delphi Crack 适用于Microsoft Office和Delphi VCL的Add-in Express使您能够在几次点击中为Microsoft Office开发专业插件。它生成基于COM的项目&#xff0c;这些项目包含Microsoft Office外接程序或智能标记的所有必要功能&#xff0…

Vue——webpack

webpack 一、Install1.全局安装2.局部安装 二、总结1.打包2.定义脚本3.配置文件定义&#xff08;webpack.config.js)4.项目重新加载依赖5.webpack打包Css6.style-loader 一、Install 1.全局安装 npm install webpack webpack-cli -g2.局部安装 以项目为单位&#xff0c;一个项…