【数据结构】--单链表力扣面试题④找链表中倒数第k个结点

news2024/9/22 5:23:09

 

目录

法一、遍历链表法

法二、快慢指针法


题述:输入一个链表,输出该链表中倒数第k个结点

示例:

输入:1,[1,2,3,4,5]

返回值:[5]

已知链表的定义和函数头FindKthToTail,让你完善FindKthToTail函数

struct ListNode
{
    int val;
    struct ListNode* next;
};
struct ListNode* FindKthToTail(struct ListNode* pListhead,int k)

法一、遍历链表法

思路:我们只要遍历链表求出链表的长度n,倒数第k个 ,即从第一个节点往后走n-k步即可找到这个节点。

#include<stdio.h>
#include<stdlib.h>

struct ListNode
{
	int val;
	struct ListNode* next;
};
struct ListNode* FindKthToTail(struct ListNode* pListhead,int k)
{	
	//1、遍历链表
	struct ListNode* temp = pListhead;
	struct ListNode* cur = pListhead;
	int len = 0;
	for (temp; temp != NULL; temp = temp->next)
	{
		len++;
	}
	for (int i = 0; i < len - k; i++)
		cur = cur->next;//往后走len-k步

	return cur;
}
int main()
{
	struct ListNode* n1 = (struct ListNode*)malloc(sizeof(struct ListNode));
	struct ListNode* n2 = (struct ListNode*)malloc(sizeof(struct ListNode));
	struct ListNode* n3 = (struct ListNode*)malloc(sizeof(struct ListNode));
	struct ListNode* n4 = (struct ListNode*)malloc(sizeof(struct ListNode));
	int k = 2;
	n1->val = 1;
	n2->val = 2;
	n3->val = 3;
	n4->val = 4;
	n1->next = n2;
	n2->next = n3;
	n3->next = n4;
	n4->next = NULL;

	struct ListNode* obj = FindKthToTail(n1,k);
	if (obj)//一定要考虑链表为空的情况是不能打印的,会非法访问内存
		printf("%d\n", obj->val);
	else
		printf("链表为空,无法寻找!\n");

	return 0;
}

法二、快慢指针法

这种方法只循环遍历了一次链表,效率更高点
 

思路:定义两个快慢指针:fast(快指针),slow(慢指针)。求倒数第k个结点,初始条件使fast和slow均指向第一个节点。因为单链表是无法倒着走的,所以对于slow,只需要正走n-k步(n为总长度)就是倒数第k个结点(这一点可以画图悉知),而这种方法就是不知道总长度n(因为这种方法要求了只能遍历链表一次),所以我们才定义了一个快指针fast,让其先走k步,那么走完之后,此时fast走到NULL时,正好为n-k步。

故总体思路:slow和fast初始均指向第一个节点,再让fast先走k步,然后slow和fast再同时走,直到fast为NULL,此时slow所指向的节点就是倒数第k个结点。(因为此时正好满足slow正走n-k步)

还要考虑临界问题:如果k>链表长度怎么办?如果为空链表怎么办?

 

#include<stdio.h>
#include<stdlib.h>

struct ListNode
{
	int val;
	struct ListNode* next;
};
struct ListNode* FindKthToTail(struct ListNode* pListhead, int k)
{
	struct ListNode* fast = pListhead, * slow = pListhead;//初始条件
	while (k--)
	{//这个循环会执行k次
	//当k=1时,k--会再循环最后一次,然后k变为0,此时fast!=NULL,如果链表长度n=k的话,
	// 那么fast=fast->next后,fast变为NULL。
		if (fast == NULL)
		{
			return NULL;
	//如果k>链表长度,会提前变为NULL,那么直接返回NULL
	//k=链表长度时是合法的,会返回slow,即第一个节点
	//而不是返回NULL,因为是先判断fast是否为NULL,然后才fast=fast->next的
	//当然,这种情况对空链表照常适用
		}
		fast = fast->next;//fast先走k步
	}
	while (fast)
	{
		slow = slow->next;
		fast = fast->next;
	}
	return slow;
}
int main()
{
	struct ListNode* n1 = (struct ListNode*)malloc(sizeof(struct ListNode));
	struct ListNode* n2 = (struct ListNode*)malloc(sizeof(struct ListNode));
	struct ListNode* n3 = (struct ListNode*)malloc(sizeof(struct ListNode));
	struct ListNode* n4 = (struct ListNode*)malloc(sizeof(struct ListNode));
	int k = 2;
	n1->val = 1;
	n2->val = 2;
	n3->val = 3;
	n4->val = 4;
	n1->next = n2;
	n2->next = n3;
	n3->next = n4;
	n4->next = NULL;

	struct ListNode* obj = FindKthToTail(n1, k);
	if (obj)//一定要考虑链表为空的情况是不能打印的,会非法访问内存
		printf("%d\n", obj->val);
	else
		printf("链表为空,无法寻找!\n");

	return 0;
}

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

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

相关文章

基于html+css的图展示81

准备项目 项目开发工具 Visual Studio Code 1.44.2 版本: 1.44.2 提交: ff915844119ce9485abfe8aa9076ec76b5300ddd 日期: 2020-04-16T16:36:23.138Z Electron: 7.1.11 Chrome: 78.0.3904.130 Node.js: 12.8.1 V8: 7.8.279.23-electron.0 OS: Windows_NT x64 10.0.19044 项目…

探索Vue的组件世界-组件复用

目录 Mixin【混入】 缺陷 HOC&#xff08;higher order component&#xff09;【高阶组件】 相比较Mixin的优点&#xff1a; 不足&#xff1a; Renderless组件【函数式组件&#xff0c;无渲染组件&#xff0c;Vue社区使用比较多的一种业务复用模式】 优点&#xff1a; M…

网上书城系统的设计与实现

背景 设计一个网上书城管理系统&#xff0c;通过这个系统能够满足网上书城的管理及用户的图书信息管理及购物功能。系统的主要功能包括&#xff1a;首页、个人中心、用户管理、图书类型管理、图书分类管理、图书信息管理、我的收藏管理、系统管理、订单管理等功能。 管理员可…

5号与25号发工资的差别这么大?我居然才知道(文末附招聘岗位)

可能是新一轮的毕业季马上就来了&#xff0c;最近热搜上出现了很多关于工作&#xff0c;收入与存款的热点。诸如#年入20万是什么水平# …… 前面的话题小编已经在上篇文章说过了&#xff0c;感兴趣的朋友可以点击这里围观↓↓↓ 『在中国&#xff0c;年收入20W是什么水平&am…

【音视频开发】常用工具软件

软件名描述MediaInfo分析视频文件VLC播放器播放测试EasyICE分析TS流flyAnalyser分析FLV格式的视频文件mp4box分析MP4格式的视频文件Audacity分析音频PCM文件Elecard_streamEye分析H.264海康YUVPlayer分析YUV

【Android入门到项目实战-- 11.2】—— 实现底部导航栏(RadioGroup+Fragment)

实现效果 效果如下&#xff0c;使用RadioGroup实现&#xff0c;不能左右滑动切换页面&#xff0c;适用于导航页里还有需要切换页面的场景&#xff0c;如果需要滑动效果&#xff0c;使用ViewPager实现。 准备工作 以下示例按照图上实现&#xff0c;具体多少个页面&#xff0c;按…

【C++刷题集】-- day2

目录 选择题 单选 编程题 OR62 倒置字符串⭐ 【题目解析】 【解题思路1】 【解题思路2】 【解题思路3】 排序子序列⭐ 【题目解析】 【解题思路】 选择题 单选 1、使用printf函数打印一个double类型的数据&#xff0c;要求&#xff1a;输出为10进制&#xff0c;输…

儿童教育软件推荐

1、出口算题系统 胡迪数学运算练习 2、迪乐姆是上海和盛实业集团有限公司注册的教育品牌&#xff0c;涵盖人工智能、科学、艺术、运动、创造力等多元教育领域&#xff0c;提供自主知识产权的全套课程产品、师资培养体系、环境创设实施等一站式素质教育个性化服务。 [1] 截止到…

【Proteus仿真】51单片机串口输出实验

【Proteus仿真】51单片机串口输出实验 &#x1f4cc;相关篇《【Proteus仿真】51单片机Blink点灯实验》&#x1f516;Proteus仿真基础实验-串口输出。&#x1f33f;Proteus8.12平台&#x1f33f;本实验代码基于VSM Studio&#xff0c;采用SDCC编译器。&#x1f33f;调试串口波特…

计算机图形学-GAMES101-12阴影

Shadow mapping 问题的提出 我们之前在进行着色时&#xff0c;对于每个物体仅考虑自己&#xff0c;而不考虑其他物体对它的影响。限定在光栅化中&#xff0c;如何解决阴影问题呢&#xff1f;阴影能被摄像机看到&#xff0c;但不能被光源所照亮。经典的Shadow mapping只能处理…

POSTGRESQL EDB 企业版 PG 15 独有功能

开头还是介绍一下群&#xff0c;如果感兴趣polardb ,mongodb ,mysql ,postgresql ,redis 等有问题&#xff0c;有需求都可以加群群内有各大数据库行业大咖&#xff0c;CTO&#xff0c;可以解决你的问题。加群请联系 liuaustin3 &#xff0c;在新加的朋友会分到2群&#xff08;共…

基于SpringBoot的人事管理系统的设计与实现

背景 人事管理管理方面的任务繁琐,以至于公司每年都在人事管理这方面投入较多的精力却效果甚微,人事管理系统的目标就是为了能够缓解人事管理工作方面面临的压力,让人事管理方面的工作变得更加高效准确。 系统架构 考虑到实际生活中在人事管理方面的需要以及对该系统认真的分…

由浅入深Netty粘包与半包解决方案

目录 1 粘包现象2 半包现象3 现象分析4 解决方案4.1 方法1&#xff1a;短链接4.2&#xff1a;方法2&#xff1a;固定长度4.3 方法3&#xff1a;固定分隔符4.4 方法4&#xff1a;预设长度 1 粘包现象 服务端代码 public class HelloWorldServer {static final Logger log Logg…

ARM的基本数据处理指令与条件代码的使用

最开始在此介绍一下CPSR寄存器中 N、Z、C、V 4位的作用&#xff1a; Bit[28]&#xff08;V&#xff09;&#xff1a; 当运算器中进行加法运算且产生符号位进位时该位自动置1&#xff0c;否则为0 当运算器中进行减法运算且产生符号位借位时该位自动置0&#xff0c;否则为1 …

js 多个小程序之间互相跳转,a小程序带参跳转到b小程序中

小程序中实现两个或者多个小程序之间互相跳转&#xff0c;a小程序带参跳转到b小程序中。 官方入口&#xff1a;wx.navigateToMiniProgram(Object object) https://developers.weixin.qq.com/miniprogram/dev/api/navigate/wx.navigateToMiniProgram.html 实现步骤&#xff1a; …

English Learning - L3 综合练习 3 VOA-Food 2023.05.17 周三

English Learning - L3 综合练习 3 VOA-Food 2023.05.17 周三 句 1句 2句 3句 4句 5句 6句 7句 8句 9句 10句 11句 12句 13句 14句 15结尾&#xff1a;注意力和记忆力&#xff0c;都是需要开垦的 句 1 注意后面的介词短语是当定语的 我们提供更多有关食物的表达。 they are f…

21 排序

文章目录 排序排序的基本概念排序方法的分类 插入排序直接插入排序性能分析代码实现 折半插入排序性能分析代码实现 希尔排序性能分析代码实现 交换排序冒泡排序分析和改进拓展&#xff08;提高冒泡效率的方法&#xff09;短路冒泡代码实现双向冒泡法&#xff08;鸡尾酒排序&am…

跟着NC学cfDNA全基因组片段化丰度谱分析

继续我们的跟着NC学系列&#xff0c;前面分享的是关于16S扩增子测序和宏基因组数据分析的。考虑到我们有许多小伙伴是做人类基因组方面的&#xff0c;这次分享一篇癌症早筛方面的&#xff0c;血液DELFI全基因组片段化丰度谱检测的分析框架。题目是&#xff1a;Detection and ch…

Fast-RCNN网络详解

文章目录 一、前言二、Fast-RCNN原理步骤2.1候选区域的生成2.2.ROI Pooling层2.3.分类器2.4.边界框的预测2.5.损失计算2.5.1.分类损失2.5.2.边界框回归损失 三、总结参考博客与视频、代码 一、前言 前面学习了SS算法、R-CNN网络&#xff0c;接下来继续学习Fast-RCNN网络。 本…

KingbaseES V8R3 备份恢复系列之 -- sys_rman备份过程分析

​ 案例说明&#xff1a; 本案例通过对KingbaseES sys_rman物理备份过程的详细描述&#xff0c;有助于在执行sys_rman过程中发生故障的分析。适用版本&#xff1a; KingbaseES V8R3 一、sys_rman执行过程简介 1. 调用select sys_start_backup()开始备份&#xff0c;sys_start_b…