题解 | #删除有序链表中重复的元素-I#

删除有序链表中重复的元素-I

http://www.nowcoder.com/practice/c087914fae584da886a0091e877f2c79

一次遍历

 * struct ListNode {
 *	int val;
 *	struct ListNode *next;
 * };
 */

class Solution {
public:
    /**
     * 
     * @param head ListNode类 
     * @return ListNode类
     */
    ListNode* deleteDuplicates(ListNode* head) {
        // write code here
        if (!head || head->next == nullptr) return head;
        ListNode* pre = head;
        ListNode* p = head->next;
        while (p != nullptr) {
            if (pre->val == p->val){
                pre->next = p->next;
                free(p);
                p = pre->next;
            }else {
                pre = p;
                p = p->next;
            }
        }
        return head;
    }
};
全部评论

相关推荐

昨天 14:26
门头沟学院 运营
点赞 评论 收藏
分享
半解316:内容充实,细节需要修改一下。 1,整体压缩为一页。所有内容顶格。 2,项目描述删除,直接写个人工作量 修改完之后还需要建议,可以私聊
点赞 评论 收藏
分享
评论
点赞
1
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务