算法篇:链表之倒数第k个节点
时间:2022-07-22
本文章向大家介绍算法篇:链表之倒数第k个节点,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
算法:
该类型的题目,核心点在于如何找到倒数第k个节点的位置,典型的操作办法是,双指针的方法。
第一个指针先偏移k个位置,第二个指针才开始执行
然后两个指针同时往后移动,第一个指针到链表尾部,第一个指针就是倒数第k个位置
题目 1 :链表中倒数第k个节点
https://leetcode-cn.com/problems/lian-biao-zhong-dao-shu-di-kge-jie-dian-lcof/
代码实现:
// 算法:这是典型的双指针的做法,
// 第一个指针先偏移k个位置,第二个指针才开始执行
// 然后两个指针同时往后移动,第一个指针到链表尾部,第一个指针就是倒数第k个位置
/**
* Definition for singly-linked list.
* type ListNode struct {
* Val int
* Next *ListNode
* }
*/
func getKthFromEnd(head *ListNode, k int) *ListNode {
c := head
for i:=0;i<k;i++ {
head = head.Next
}
for head != nil {
c = c.Next
head = head.Next
}
return c
}
执行结果:
题目2: 删除倒数第k个节点
https://leetcode-cn.com/problems/remove-nth-node-from-end-of-list/submissions/
代码实现:
// 算法:该问题是题目1的变形题目,
// 采用题目1的算法找到倒数第k个节点的前序节点,然后删除倒数第k个节点
/**
* Definition for singly-linked list.
* type ListNode struct {
* Val int
* Next *ListNode
* }
*/
func removeNthFromEnd(head *ListNode, n int) *ListNode {
head1 := head
head2 := head
for i:=n; i>0; i-- {
head2 = head2.Next
}
if head2 == nil {
head = head.Next
return head
}
for {
if head2.Next == nil {
break
}
head2 = head2.Next
head1 = head1.Next
}
// 获取到 倒数第n-1位置的节点
head1.Next = head1.Next.Next
return head
}
执行结果:
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- 小浩发现这篇浮点数的文章讲的真不错!
- 安全攻击溯源思路及案例
- 图解:「归并排序」
- STM32CubeMX6.0 + HAL + LittleVGL7.6 等学习[最全附工程源码]
- 国庆期间,我造了台计算机
- 编程语言的 IDE 支持
- 独家 | 手把手教你用Python的Prophet库进行时间序列预测
- 【Git】:基础的基础
- windows解决SpringBoot启动时:APPLICATION FAILED TO START
- 【Git】:基础操作篇
- 低光照图像增强算法汇总
- 用Python解决女朋友看电影没字幕的需求
- 【Git】:基础协作篇
- 最近,我用pandas处理了一把大数据……
- 【编译技术】:AST——基础的基础