今天两个很简单,就写一起了吧~
👋
My apps
- | 扫雷Elic 无尽天梯 | 梦见账本 |
---|---|---|
类型 | 游戏 | 财务 |
AppStore | Elic | Umemi |
一、22.链表中倒数第k个节点
题目
输入一个链表,输出该链表中倒数第k个节点。为了符合大多数人的习惯,本题从1开始计数,即链表的尾节点是倒数第1个节点。
例如,一个链表有 6 个节点,从头节点开始,它们的值依次是 1、2、3、4、5、6。这个链表的倒数第 3 个节点是值为 4 的节点。
示例:
给定一个链表: 1->2->3->4->5, 和 k = 2.
返回链表 4->5.
通过次数193,790提交次数246,166
来源:力扣(LeetCode)
链接:leetcode-cn.com/problems/li…
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
解法一:栈
func getKthFromEnd(_ head: ListNode?, _ k: Int) -> ListNode? {
var node = head
var temp: [ListNode] = []
while let currentNode = node {
temp.insert(currentNode, at: 0)
if temp.count > k {
temp.removeLast()
}
node = currentNode.next
}
return temp.last
}
解法二:差速双指针
func getKthFromEnd(_ head: ListNode?, _ k: Int) -> ListNode? {
var right: ListNode? = head, left: ListNode? = head
// 移动到 第 k 个节点
for _ in 0..<k-1 {
right = right?.next
}
while let _ = right?.next {
right = right?.next
left = left?.next
}
return left
}
二、24.反转链表
题目
定义一个函数,输入一个链表的头节点,反转该链表并输出反转后链表的头节点。
示例:
输入: 1->2->3->4->5->NULL
输出: 5->4->3->2->1->NULL
限制:
0 <= 节点个数 <= 5000
注意:本题与主站 206 题相同:leetcode-cn.com/problems/re…
- 来源:力扣(LeetCode)
- 链接:leetcode-cn.com/problems/fa…
- 著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
解法
func reverseList(_ head: ListNode?) -> ListNode? {
var node: ListNode?
var temp: ListNode? = head
while let current = temp {
let n = ListNode(current.val)
n.next = node
node = n
temp = current.next
}
return node
}