83. 删除排序链表中的重复元素
温馨提示:
本文最后更新于 2022年12月07日,已超过 883 天没有更新。若文章内的图片失效(无法正常加载),请留言反馈或直接联系我。
83. 删除排序链表中的重复元素
一次循环遍历解法:
时间复杂度:O(n)
空间复杂度:O(1)
class Solution {
public ListNode deleteDuplicates(ListNode head) {
if (null == head) {
return head;
}
// - 初始化一个当前节点的指针
ListNode currentNode = head;
while (null != currentNode.next){
// - 如果当前节点和下一个节点相同
if(currentNode.next.val == currentNode.val){
// - 下一个节点 = 下一个节点的下一个节点 == 删除节点
currentNode.next = currentNode.next.next;
} else {
currentNode = currentNode.next;
}
}
// - 返回相同节点后的链表
return head;
}
}
递归解法:
时间复杂度:O(n)
空间复杂度:O(n^2)
class Solution {
public ListNode deleteDuplicates(ListNode head) {
if (null == head || null == head.next) {
return head;
}
// - 递归处理
head.next = deleteDuplicates(head);
// - 关键代码: 如果相同则返回 下一个节点
return head.val == head.next.val ? head.next : head;
}
}
正文到此结束
- 本文标签: Leet-Code 链表 递归
- 本文链接: http://www.ityoulove.com/article/21
- 版权声明: 本文由崔健宇原创发布,转载请遵循《署名-非商业性使用-相同方式共享 4.0 国际 (CC BY-NC-SA 4.0)》许可协议授权