题库一、反转链表
三指针解法 二、删除排序链表中的重复元素
1.双指针解法(个人想法,更节省空间)2.单指针解法 总结
题库 一、反转链表
给你单链表的头节点 head ,请你反转链表,并返回反转后的链表。原题
三指针解法建立三个工作指针 p1,p2,p3 ,遍历链表,p1指向当前元素,p2指向下一个元素,p3指向p2的下一个元素,依靠三个指针互相变化来反转链表。
代码如下:
if(head == null)
return head;
ListNode p1 = head,p2 = head.next;
head.next = null;
while(p2 != null) {
ListNode p3 = p2.next;
p2.next = p1;
p1 = p2;
p2 = p3;
}
return p1;
二、删除排序链表中的重复元素
给定一个已排序的链表的头 head , 删除所有重复的元素,使每个元素只出现一次 。返回 已排序的链表 。原题
1.双指针解法(个人想法,更节省空间)建立两个指针 p1,p2 ,遍历链表,p1指向当前元素,p2指向下一个元素,若p1和p2的值相同,则p2指向下一个元素,反之,则p1和p2都指向下一个元素。
代码如下:
if(head == null)
return head;
ListNode p1 = head,p2 = head.next;
while(p2 != null) {
if(p1.val == p2.val) {
p2 = p2.next;
continue;
}
p1.next = p2;
p1 = p2;
p2 = p2.next;
}
p1.next = null;
return head;
2.单指针解法
建立一个指针p指向当前元素,若p的值和下一个元素值相等,则p的next指针跳过这个元素,反之,则p指向下一个元素。
代码如下:
if(head == null)
return head;
ListNode p = head;
while(p.next != null) {
if(p.val == p.next.val) {
p.next = p.next.next;
}else {
p = p.next;
}
}
return head;
总结



