标签:|| 仓库 优先 调整数组顺序 两个栈实现队列 复杂链表 需求 翻转单词顺序 and
重磅干货,第一时间送达删除链表中重复的结点
在一个排序的链表中,存在重复的结点,请删除该链表中重复的结点,重复的结点不保留,返回链表头指针。例如,链表1->2->3->3->4->4->5 处理后为 1->2->5
一开始觉得哇这题目好简单,不过是找到需要删除的节点,然后跳过该节点就行了。
思路A:新建一个哈希表,由于链表是有序的,将所有的元素出现次数记录下来,然后再开辟个链表还原现场。
我们采用最容易想到的方法,不用考虑时间效率与空间效率问题,就直接用遍历,用一个哈希表结构来记录每个节点对应的值在节点中出现了几次,统计完成后,然后通过哈希表中如果出现次数为大于等于2,再用两个指针一个前一个后开始找对应的值就行了,如果后一个指针指向的节点的值为哈希表中出现次数大于等于2的数,那么前一个指针指向后一个指针的next然后删除后一个指针所指向的节点,让后一个指针重新指向前一个指针的next,就这样就可以完成删除。
虽然这个方法可以,但是时间复杂度为O(N), 空间复杂度为一个哈希表的结构,所以采用这种不是最佳选择。
哈希表O(N),链表也是O(N),时间复杂度O(N)
思路B:思路A当然是暴力解法,要是空间有限制那就不行了。既然是链表结构,我们就要学会巧用指针,一个指针不能满足需求那就用两个指针,这样空间复杂度可以降到最小,时间复杂度即便是O(N+M)也可以约等于O(N)
2.设置pre ,last指针, pre指针指向当前确定不重复的那个节点,而last指针相当于工作指针,一直往后面搜索。
# -*- coding:utf-8 -*-
# class ListNode:
# def __init__(self, x):
# self.val = x
# self.next = None
class Solution:
def deleteDuplication(self, pHead):
# write code here
if not pHead or pHead.next==None:
return pHead
Head=ListNode(0)
Head.next=pHead
pre=Head
last=pHead
while last!=None:
if last.next!=None and last.val == last.next.val :
while last.next!=None and last.val==last.next.val :
last=last.next
pre.next=last.next
last=last.next
else:
pre=pre.next
last=last.next
return Head.next
if (pHead==null || pHead.next==null){return pHead;}
ListNode Head = new ListNode(0);
Head.next = pHead;
ListNode pre = Head;
ListNode last = Head.next;
while (last!=null){
if(last.next!=null && last.val == last.next.val){
// 找到最后的一个相同节点
while (last.next!=null && last.val == last.next.val){
last = last.next;
}
pre.next = last.next;
last = last.next;
}else{
pre = pre.next;
last = last.next;
}
}
return Head.next;
注:面试季来了,不管是作为面试者还是以后作为面试官,了解算法这门程序员之间的沟通方式都是非常必要的。找过工作的朋友应该都听说过《剑指offer》,虽然书中只有六十多道题目,但是道道都是经典。
如果是单纯的面试需求,剑指offer的优先级肯定是在Leetcode之前,总的说它有三个优点:
它的缺点是:
2.动态规划的题比较少,因此需要在Leetcode上专项训练。
算法题主要分成数据结构和具体算法部分,简单归类如下。基本每道题都很精彩,所以这里就不一一洗写了,题解可以看看我的代码仓库或者讨论区的内容。
以下是剑指offer题目,蓝色为已发布连接。
剑指offer刷题交流群
扫码添加微信,一定要备注研究方向+地点+学校+昵称(如机器学习+上海+上交+汤姆),只有备注正确才可以加群噢。
▲长按加群
每日算法题 | 剑指offer 链表专题 (8) 删除链表中重复的结点
标签:|| 仓库 优先 调整数组顺序 两个栈实现队列 复杂链表 需求 翻转单词顺序 and
原文地址:https://blog.51cto.com/15054042/2564456