【剑指Offer-Swift】22.链表中倒数第k个节点 & 24.反转链表

564 阅读1分钟

今天两个很简单,就写一起了吧~

👋

My apps

-扫雷Elic 无尽天梯梦见账本
类型游戏财务
AppStoreElicUmemi

一、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…

著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

GitHub

解法一:栈

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…
  • 著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

解法

GitHub

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
}