删除排序链表中的重复元素
作者:互联网
删除排序链表中的重复元素
一、题目描述
给定一个已排序的链表头head,删除所有的重复的元素,使每个元素只能出现依次。返回已排序的连链表。
实例
输入:head = [1,1,2]
输出:[1,2]
输入:head = [1,1,2,3,3]
输出:[]1,2,3]
二、题目分析
链表的形式,删除相同的元素,链表也是有序的,相同的元素是两连的,只需要判断相邻的元素是否相等。
三、解题思路
遍历整个链表。判断相邻元素是否相等。使用head.next.val == head.next.next.val.即可、相等的话,直接跳过相等元素,直接连接到下下一个元素即可。
public ListNode deleteDuplicates(ListNode head) {
if(head == null){
return null;
}
ListNode pro = head;
while(pro.next != null){
if(pro.val == pro.next.val){
pro.next = pro.next.next;
}else{
pro = pro.next;
}
}
return head;
}
标签:head,val,删除,pro,元素,next,链表,排序 来源: https://www.cnblogs.com/zjjtt/p/16687717.html