重磅干货,第一时间送达程序员
删除链表中重复的结点面试
在一个排序的链表中,存在重复的结点,请删除该链表中重复的结点,重复的结点不保留,返回链表头指针。例如,链表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以前,总的说它有三个优势:ide
它的缺点是:函数
2.动态规划的题比较少,所以须要在Leetcode上专项训练。
算法题主要分红数据结构和具体算法部分,简单归类以下。基本每道题都很精彩,因此这里就不一一洗写了,题解能够看看个人代码仓库或者讨论区的内容。
如下是剑指offer题目,蓝色为已发布链接。
剑指offer刷题交流群
扫码添加微信,必定要备注研究方向+地点+学校+昵称(如机器学习+上海+上交+汤姆),只有备注正确才能够加群噢。
▲长按加群