链表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.mzph.cn/news/62059.shtml

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

相关文章

【 OpenGauss源码学习 —— 列存储(analyze)(二)】

列存储&#xff08;analyze&#xff09; 概述analyze_get_relation 函数VacuumStmt 结构体Relation 结构体代码段解读try_relation_open 函数ConditionalLockRelationOid 函数 analyze_rel_internal 函数BufferAccessStrategy 结构体GBLSTAT_HDFS_SAMPLE_ROWS 结构体do_analyze…

构建简单的Node.js HTTP服务器,发布公网远程访问的快速方法

文章目录 前言1.安装Node.js环境2.创建node.js服务3. 访问node.js 服务4.内网穿透4.1 安装配置cpolar内网穿透4.2 创建隧道映射本地端口 5.固定公网地址 前言 Node.js 是能够在服务器端运行 JavaScript 的开放源代码、跨平台运行环境。Node.js 由 OpenJS Foundation&#xff0…

Golang 中的 archive/zip 包详解(二):常用类型

Golang 中的 archive/zip 包用于处理 ZIP 格式的压缩文件&#xff0c;提供了一系列用于创建、读取和解压缩 ZIP 格式文件的函数和类型&#xff0c;使用起来非常方便。 zip.File 类型 定义如下&#xff1a; type File struct {FileHeaderzip *Readerzipr io…

【附安装包】Substance3D 2022安装教程

软件下载 软件&#xff1a;Substance3D版本&#xff1a;2022语言&#xff1a;简体中文大小&#xff1a;4.0G安装环境&#xff1a;Win11/Win10&#xff08;1809版本以上&#xff09;硬件要求&#xff1a;CPU2.0GHz 内存4G(或更高&#xff0c;不支持7代以下CPU&#xff09;下载通…

thinkphp6 入门(2)--视图、渲染html页面、赋值

修改模板引擎 config/view.php // 模板引擎类型使用Think type > php, 2. 新建一个控制器 本文app的名称为test&#xff0c;在其下新建一个控制器User app/test/controller/User.php 注意&#xff1a;需要引用think\facade\View来操作视图 <?phpnamespace app\te…

MySQL与Oracle数据库通过系统命令导出导入

MySQL导出 mysqldump -uroot -ppassword 库名 表名 --where"s_dtend<2023-05-01 00:00:00 and s_dtend>2023-01-01 00:00:00 and (i_mbr!10000 OR (i_mbr 10000 AND I_ACTV IN (SELECT I_ACTV FROM t_mk_activity WHERE S_DTEND < 2023-05-01 00:00:00)))"…

h5 ws 客户端 监听ws服务器广播的信息

<!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><title>AI智能写作</title><!-- Bootstrap CSS --><meta charset"utf-8"><meta name"viewport" content"widt…

react中受控组件与非受控组件

受控组件与非受控组件 受控组件: 其值由 React 控制的组件,通常使用 state 来控制和修改组件的值。 例如受控的 组件: class NameForm extends React.Component {constructor(props) {super(props);this.state {value: };}handleChange (event) > {this.setState({val…

K8s的Pod出现Init:ImagePullBackOff问题的解决(以calico为例)

对于这类问题的解决思路应该都差不多&#xff0c;本文以calico插件安装为例&#xff0c;发现有个Pod的镜像没有pull成功 第一步&#xff1a;查看这个pod的描述信息 kubectl describe pod calico-node-wmhrw -n kube-system 从上图发现是docker拉取"calico/cni:v3.15.1&q…

Redis面试题总结

1.什么是Redis Redis 是一种基于内存的数据库对数据的读写操作都是在内存中完成&#xff0c;因此读写速度非常快&#xff0c;常用于缓存&#xff0c;消息队列、分布式锁等场景。 Redis 提供了多种数据类型来支持不同的业务场景&#xff0c;比如 String(字符串)、Hash(哈希)、…

Ubuntu 20.04.5 怎么安装微信

这是我的ubutun版本号 在这个系统装桌面版微信很多功能不健全。搜索了很多方法&#xff0c;这个算是不错的一个法子。 1.添加仓库 首次使用时&#xff0c;你需要运行如下一条命令将移植仓库添加到系统中。 wget -O- https://deepin-wine.i-m.dev/setup.sh | sh 2.应用安装 …

【C语言】文件操作详解

文章目录 前言一、文件是什么二、文件具体介绍1.文件名2.文件类型3.文件缓冲区4.文件指针5.文件的打开和关闭 三、文件的顺序读写1.字符输入函数&#xff08;fgetc&#xff09;2.字符输出函数&#xff08;fputc&#xff09;3.文本行输入函数&#xff08;fgets&#xff09;4.文本…

基于MQTT协议的物联网关

随着工业领域的不断发展&#xff0c;数字化转型已经成为企业迈向未来的必由之路。在这个数字化浪潮中&#xff0c;HiWoo Box以其强大的功能和创新的设计&#xff0c;在工业物联网领域被越来越多的人所熟知。特别是其基于MQTT协议的物联网关能力&#xff0c;也为企业实现智能化数…

网络媒介素养研究及其教育

我们知道网络传播作为第四媒体不同于传统的大众传播媒体&#xff0c;网络不仅仅是人 际传播与大众传播的综合体&#xff0c;也是多媒体传播的复合体。即网络传播的文本特征是 多媒体传播&#xff0c;以超链接的形式集文字、影像、音频、视频于一体。这就要求网民以 不同的技…

Centos7本地安装Docker-compose

考虑github时常出现问题。以下内容是基于本地安装 安装包地址 文章参考链接 1、下载安装包上传包到/usr/local/bin 2、执行命令 # 修改权限 chmod x /usr/local/bin/docker-compose ln -s /usr/local/bin/docker-compose /usr/bin/docker-compose3、验证是否安装成功 docker-…

制作 linux .deb 安装包

文章目录 打包controlpostinstpostrmTestApp.shTestApp.desktop生成安装包安装.deb卸载 [Qt 发布应用程序](https://blog.csdn.net/u012020854/article/details/52597226?spm1001.2014.3001.5502) 新增文件夹 packages 打包 packages ├── DEBIAN │ └── control #详情看…

「操作系统」1. 基础

前言&#xff1a;操作系统基础八股文 文章目录 一 、操作系统基础1.1 什么是操作系统&#xff1f;1.2 什么是系统调用1.3 什么是中断 &#x1f680; 作者简介&#xff1a;作为某云服务提供商的后端开发人员&#xff0c;我将在这里与大家简要分享一些实用的开发小技巧。在我的职…

使用 python 源码搭建 conda 环境

今天需要使用 python 2.6.8 的环境&#xff0c;发现 conda 设置成清华源后&#xff0c;没有旧版本了。所以打算从官网上下载一份 python 进行安装&#xff0c; 结果发现&#xff0c;conda 不能直接安装离线包&#xff08;也可能我没找到方法&#xff09;&#xff0c;经过一番尝…

既能够用ffmpeg命令做RTSP流转RTMP流,又可以像调用avcodec/avfilter库一样逻辑编程

又有一个需求&#xff1a;我们现在想做一款多路RTSP拉流转RTMP推流到CDN进行直播的功能&#xff0c;注意啊&#xff0c;是多路&#xff0c;原来我们有两种方式&#xff0c;一种是用ffmpeg.exe进行&#xff1a; ffmpeg -i “rtsp://192.168.0.99:8554/1” -c:v libx264 -c:a aac…

java 多线程

01.多线程类java.lang.Thread 这里继承Thread类的方法是比较常用的一种&#xff0c;如果说你只是想起一条线程。没有什么其它特殊的要求&#xff0c;那么可以使用Thread.&#xff08;笔者推荐使用Runable&#xff0c;后头会说明为什么&#xff09;。下面来看一个简单的实例&…