数据结构:力扣OJ题

news/2024/10/19 19:33:22/

目录

​编辑题一:链表分割

思路一:

题二:相交链表

思路一:

题三:环形链表

 思路一:

题四:链表的回文结构

思路一:

链表反转:

查找中间节点:

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


题一:链表分割

现有一链表的头指针 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.ppmy.cn/news/1026328.html

相关文章

【ES6】深入理解ES6(1)

一、块级作用域绑定 var声明及变量提升机制 二、字符串和正则表达式 字符串&#xff08;String&#xff09;是JavaScript6大原始数据类型。其他几个分别是Boolean、Null、Undefined、Number、Symbol&#xff08;es6新增&#xff09;。 更好的Unicode支持 1. UTF-16码位 字…

Python中的txt文件读取方法

Python中的txt文件读取方法 注&#xff1a;以txt中带制表符和换行符的文件为例 函数strip()&#xff0c;除去某部分&#xff0c;比如’\n’符号&#xff0c;strip(‘\n’) 函数split()&#xff0c;以某些字符做分割&#xff0c;比如’\t’符号&#xff0c;split(‘\t’) 举例&…

什么是ServiceMesh(Istio一)

现在最火的后端架构无疑是微服务了&#xff0c;微服务将之前的单体应用拆分成了许多独立的服务应用&#xff0c;每个微服务都是独立的&#xff0c;好处自然很多&#xff0c;但是随着应用的越来越大&#xff0c;微服务暴露出来的问题也就随之而来了&#xff0c;微服务越来越多&a…

Baklib: 逆袭语雀的在线帮助中心,知识库管理工具

1. 介绍 在现代的技术发展中&#xff0c;知识管理变得越来越重要。特别是对于企业来说&#xff0c;拥有一个高效的知识库管理工具可以极大地提高工作效率和团队合作。Baklib就是这样一款在线帮助中心和知识库管理工具&#xff0c;它可以帮助企业集中管理和共享知识&#xff0c…

7.利用matlab完成 符号方阵的特征值分解和 符号矩阵的奇异值分解 (matlab程序)

1.简述 &#xff08;1&#xff09;特征值分解&#xff1a;函数eig 格式&#xff1a;[V,D] eig(A) %计算A的特征值对角阵D和特征向量V&#xff0c;使AVVD成立。 注意&#xff1a;特征值分解时&#xff0c;使用eig&#xff0c;矩阵A必须是方阵。 A [0 1;1 1]; [V,D] ei…

CAN总线分析仪

文章目录 一、CAN总线分析仪设计二、CAN网络分析仪上位机三、开发一款CAN网络分析仪上位机步骤四、市场上有哪些CAN网络分析仪五、 VN1630介绍六、CANoe介绍一、CAN总线分析仪设计 CAN总线分析仪是一种用于监控和分析CAN(控制器局域网)总线上数据通信的设备。它可以帮助工程…

四、web应用程序技术——HTTP

文章目录 1 HTTP请求2 HTTP响应3 HTTP方法4 URL5 HTTP消息头5.1 常用消息头5.2 请求消息头5.3 响应消息头 6 cookie7 状态码8 HTTP代理9 HTTP身份验证 HTTP&#xff08;HyperText Transfer Protocol&#xff0c;超文本传输协议&#xff09;是访问万维网使用的核心通信协议&…

腾讯云服务器CVM标准型S5详细介绍及其他S6、SA3实例等

腾讯云CVM服务器标准型实例的各项性能参数平衡&#xff0c;标准型云服务器适用于大多数常规业务&#xff0c;例如&#xff1a;web网站及中间件等&#xff0c;常见的标准型云服务器有CVM标准型S5、S6、SA3、SR1、S5se等规格&#xff0c;腾讯云服务器网来详细说下云服务器CVM标准…