83.删除排序链表中的重复元素
给定一个排序链表,删除所有重复的元素,使得每个元素只出现一次。
示例 1:
输入: 1->1->2
输出: 1->2
示例 2:
输入: 1->1->2->3->3
输出: 1->2->3
暴力枚举
/**
* Definition for singly-linked list.
* struct ListNode {
* int val;
* struct ListNode *next;
* };
*/
struct ListNode* deleteDuplicates(struct ListNode* head) {
struct ListNode *p = head;
while (p != NULL && p->next != NULL) {
if (p->next->val == p->val) {
p->next = p->next->next;
} else {
p = p->next;
}
}
return head;
}
思维变换
/**
* Definition for singly-linked list.
* struct ListNode {
* int val;
* struct ListNode *next;
* };
*/
struct ListNode* deleteDuplicates(struct ListNode* head) {
struct ListNode *p = head, *q;
while (p && p->next) {
if (p->val - p->next->val) {
p = p->next;
} else {
q = p->next;
p->next = q->next;
free(q);
}
}
return head;
}