链表OJ练习(1)

一、移除链表元素

本题为力扣原题203

题目介绍:

给你一个链表的头节点 head 和一个整数 val ,请你删除链表中所有满足 Node.val == val 的节点,并返回 新的头节点 。

列表中的节点数目范围在 0~10000内

1<=Node.val<=50

0<=val<=50 

 思路:利用双指针解决,struct ListNode*dst=NULL;struct ListNode*cur=head;利用指针cur便利整个链表。

注:需要考虑到要删除的是否是头节点。

让我们看看如何来实现:

/*** Definition for singly-linked list.* struct ListNode {*     int val;*     struct ListNode *next;* };*/struct ListNode* removeElements(struct ListNode* head, int val)
{struct ListNode*dst=NULL;struct ListNode*cur=head;while(cur){if(cur->val==val){//找到了,删除if(cur==head){head=cur->next;free(cur);cur=head;}else{dst->next=cur->next;free(cur);cur=dst->next;}}else {dst=cur;cur=cur->next;}}return head;
}

二、反转链表

本题为力扣原题206

题目介绍:

给你单链表的头节点 head ,请你反转链表,并返回反转后的链表。

思路:利用三指针解决,指针n1和n2用来交换指向,至真n3用来找到下一个节点。

注:需要注意的是判断指针在什么情况下为空,避免利用空指针。n1最开始为空。

让我们看看如何来实现:

/*** Definition for singly-linked list.* struct ListNode {*     int val;*     struct ListNode *next;* };*/struct ListNode* reverseList(struct ListNode* head)
{struct ListNode*n1;struct ListNode*n2;struct ListNode*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;
}

三、链表的中间节点

本题为力扣原题876

题目介绍:

给你单链表的头结点 head ,请你找出并返回链表的中间结点。

如果有两个中间结点,则返回第二个中间结点

思路:快慢指针,快指针每次走两步,慢指针每次走一步,当快指针到达尾部时,慢指针刚好到达中间节点

让我们看看如何来实现:

/*** Definition for singly-linked list.* struct ListNode {*     int val;*     struct ListNode *next;* };*///快慢指针
struct ListNode* middleNode(struct ListNode* head)
{struct ListNode* falst;struct ListNode* slow;falst=head;slow=head;while(falst&&falst->next){slow=slow->next;falst=falst->next->next;}return slow;
}

四、返回倒数第k个节点

题目介绍;

输入一个长度为 n 的链表,设链表中的元素的值为 ai ,返回该链表中倒数第k个节点。

如果该链表长度小于k,请返回一个长度为 0 的链表。

思路:和上面一题很相似,还是用快慢指针,只不过这次是让,快慢指针都开始指向头节点,让快指针先走k步,然后慢指针和快指针在同时往后走,当快指针到达尾的时候,慢指针就指向了倒数第k个元素了。

注:这里需要注意的是k的大小,当k大于链表长度是就会溢出,这里我们直接返回NULL。

让我们看看如何来实现:

/*** struct ListNode {*	int val;*	struct ListNode *next;* };*/
/*** 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可** * @param pHead ListNode类 * @param k int整型 * @return ListNode类*/
struct ListNode* FindKthToTail(struct ListNode* pHead, int k ) 
{if(pHead==NULL){return NULL;}struct ListNode*slow=pHead;struct ListNode*falst=pHead;int len=0;while(pHead){len++;pHead=pHead->next;}if(k>len){return NULL;}while(k){falst=falst->next;k--;}while(falst){falst=falst->next;slow=slow->next;}return slow;
}

五、合并两个有序链表

题目介绍:

将两个升序链表合并为一个新的 升序 链表并返回。新链表是通过拼接给定的两个链表的所有节点组成的。 

思路:首先先考虑特殊情况,当链表一为空是返回链表二,链表二为空时返回链表一。然后我们开始遍历链表一和链表二,比较两个指针指向链表的元素大小,创建一个新链表头节点,将小的元素的节点尾插到新链表上,然后将较小元素的指针后移,然后在比较......如果最后链表一遍历完了,就可以将指向链表二的指针指向新链表的尾部,最后然会新链表的头节点。

注:题目时不带头节点的,所以我们创建玩心链表的头节点需要销毁,头指针指向头节点的下一个节点。

struct ListNode* mergeTwoLists(struct ListNode* list1, struct ListNode* list2)
{if(list1==NULL){return list2;}if(list2==NULL){return list1;}struct ListNode*tail=NULL;struct ListNode*head=NULL;head=tail=(struct ListNode*)malloc(sizeof(struct ListNode));while(list1&&list2){if(list2->val>list1->val){tail->next=list1;tail=tail->next;list1=list1->next;}else{tail->next=list2;tail=tail->next;list2=list2->next;}   }if(list1){tail->next=list1;}if(list2){tail->next=list2;}struct ListNode* del=head;head=head->next;free(del);return head;
}

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

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

相关文章

Hadoop HA模式切换

Hadoop HA模式下 主从的切换&#xff08;操作命令&#xff09; YARN HA 获取所有RM节点的状态 yarn rmadmin -getAllServiceState获取 rm1 节点的状态 yarn rmadmin -getServiceState rm1手动将 rm1 的状态切换到STANDBY yarn rmadmin -transitionToStandby rm1 ##或者 y…

智能电话机器人的出现,能够解决哪些问题?

经济的繁荣与高速的发展&#xff0c;使得电销这个方式快速地融合在房地产与金融投资等大部分行业上。在电销人员与客户的沟通上&#xff0c;难免会出现很多问题&#xff0c;毕竟所面对的客户都是各行各业&#xff0c;他们有着不同的经历和身份。 对于时常需要处理客户投诉、安…

华为云Stack的学习(三)

四、华为云Stack公共组件 1.华为云Stack公共负载均衡方案介绍 1.1 LVS原理 LVS是四层负载均衡&#xff0c;建立在OSI模型的传输层之上&#xff0c;所以效率非常高。 LVS有两种转发模式&#xff1a; NAT模式的转发主要通过修改IP地址&#xff08;位于OSI模型的第三层网络层&…

springboot+activiti5.0整合(工作流引擎)

概述 springboot整合activiti使用modeler进行流程创建&#xff0c;编辑、部署以及删除实例&#xff08;可运行&#xff09; 详细 1、现在来说一下流程&#xff0c;先建立spring boot项目&#xff0c;导入对应的jar包。 <dependencies><dependency><groupId&…

在 AWS 中导入 qcow2 镜像

文章目录 在 AWS 中导入 qcow2 镜像使用的格式和问题步骤概述前提条件转换镜像格式并上传至 S3创建角色并配置策略策略文件内容创建container.json配置文件导入镜像创建 AMI 并启动实例参考:在 AWS 中导入 qcow2 镜像 当我们在多云环境中部署应用时,有时候可能需要把基于 qem…

计算机毕设之基于python+django+mysql的影片数据爬取与数据分析(包含源码+文档+部署教程)

影片数据爬取与数据分析分为两个部分&#xff0c;即管理员和用户。该系统是根据用户的实际需求开发的&#xff0c;贴近生活。从管理员处获得的指定账号和密码可用于进入系统和使用相关的系统应用程序。管理员拥有最大的权限&#xff0c;其次是用户。管理员一般负责整个系统的运…

气传导蓝牙耳机好不好?推荐几款不错的气传导耳机

​在众多的气传导耳机中&#xff0c;如何选择一款适合自己的气传导耳机呢&#xff1f;这需要考虑到自己的需求和预算&#xff0c;同时也需要了解不同品牌和型号的产品特点和优缺点。下面我来推荐几款非常不错的气传导耳机给大家参考&#xff0c;希望大家都能寻找到心仪那款。 …

图像处理 信号处理板 设计原理图:367-基于zynq XC7Z100 FMC接口通用计算平台

基于zynq XC7Z100 FMC接口通用计算平台 一、板卡概述 板卡由SoC XC7Z100-2FFG900I芯片来完成卡主控及数字信号处理&#xff0c;XC7Z100内部集成了两个ARM Cortex-A9核和一个kintex 7的FPGA&#xff0c;通过PL端FPGA扩展FMC、光纤、IO等接口&#xff0c;PS端ARM扩展网络、USB、R…

基于VUE3+Layui从头搭建通用后台管理系统(前端篇)十一:通用表单组件封装实现

一、本章内容 本章实现通用表单组件,根据实体配置识别实体属性,并自动生成编辑组件,实现对应数据填充、校验及保存等逻辑。 1. 详细课程地址: 待发布 2. 源码下载地址: 待发布 二、界面预览 三、开发视频 3.1 B站视频地址:

计算机视觉-LeNet

目录 LeNet LeNet在手写数字识别上的应用 LeNet在眼疾识别数据集iChallenge-PM上的应用 LeNet LeNet是最早的卷积神经网络之一。1998年&#xff0c;Yann LeCun第一次将LeNet卷积神经网络应用到图像分类上&#xff0c;在手写数字识别任务中取得了巨大成功。LeNet通过连续使用…

素数之谜揭秘:一文详解试除法判断素数

这是我非常喜欢的一道编程题目。不要小看这道题&#xff0c;它看似简单&#xff0c;实则奥妙无穷。由于这是C语言的入门篇&#xff0c;只介绍最简单&#xff0c;也最容易想到的方法&#xff1a;试除法。但哪怕是试除法&#xff0c;也有不少变化。 要想了解试除法&#xff0c;首…

C# char曲线控件

一、char曲线显示随机数数据 using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Drawing; using System.Linq; using System.Runtime.InteropServices; using System.Text; using System.Threading; using Syst…